# Synopsys® Timing Constraints and Optimization User Guide

Version C-2009.06, June 2009

SYNOPSYS®

# **Copyright Notice and Proprietary Information**

Copyright © 2009 Synopsys, Inc. All rights reserved. This software and documentation contain confidential and proprietary information that is the property of Synopsys, Inc. The software and documentation are furnished under a license agreement and may be used or copied only in accordance with the terms of the license agreement. No part of the software and documentation may be reproduced, transmitted, or translated, in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without prior written permission of Synopsys, Inc., or as expressly provided by the license agreement.

#### **Right to Copy Documentation**

The license agreement with Synopsys permits licensee to make copies of the documentation for its internal use only. Each copy shall include all copyrights, trademarks, service marks, and proprietary rights notices, if any. Licensee must assign sequential numbers to all copies. These copies shall contain the following legend on the cover page:

| "This document is duplicated with the permission of S | Synopsys, Inc., for the exclusive use of |   |
|-------------------------------------------------------|------------------------------------------|---|
|                                                       | and its employees. This is copy number   | , |

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### Disclaimer

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### Registered Trademarks (®)

Synopsys, AMPS, Astro, Behavior Extracting Synthesis Technology, Cadabra, CATS, Certify, CHIPit, Design Compiler, DesignWare, Formality, HDL Analyst, HSIM, HSPICE, Identify, iN-Phase, Leda, MAST, ModelTools, NanoSim, OpenVera, PathMill, Physical Compiler, PrimeTime, SCOPE, Simply Better Results, SiVL, SNUG, SolvNet, Syndicated, Synplicity, Synplify Pro, Synthesis Constraints Optimization Environment, TetraMAX, the Synplicity logo, UMRBus, VCS, Vera, and YIELDirector are registered trademarks of Synopsys, Inc.

#### Trademarks (™)

AFGen, Apollo, Astro-Rail, Astro-Xtalk, Aurora, AvanWaves, BEST, Columbia, Columbia-CE, Confirma, Cosmos, CosmosLE, CosmosScope, CRITIC, CustomSim, DC Expert, DC Professional, DC Ultra, Design Analyzer, Design Vision, DesignerHDL, DesignPower, DFTMAX, Direct Silicon Access, Discovery, Eclypse, Encore, EPIC, Galaxy, Galaxy Custom Designer, HANEX, HAPS, HapsTrak, HDL Compiler, Hercules, Hierarchical Optimization Technology, High-performance

ASIC Prototyping System, HSIM plus in invitable some plus in invitable some plus plus in invitable some plus plus in invitable some plus invitable some plus in invitable some plus in invitable some plus in invitable some plus invit

#### Service Marks (SM)

MAP-in, SVP Café, and TAP-in are service marks of Synopsys, Inc.

SystemC is a trademark of the Open SystemC Initiative and is used under license. ARM and AMBA are registered trademarks of ARM Limited. Saber is a registered trademark of SabreMark Limited Partnership and is used under license. All other product or company names may be trademarks of their respective owners.

|    | What's New in This Release                    |
|----|-----------------------------------------------|
|    | About This Manual                             |
|    | Customer Support                              |
| 1. | Introduction to Synthesis Timing              |
|    | Static Timing Analysis                        |
|    | Timing Paths                                  |
|    | Clocks                                        |
|    | Input and Output Delays                       |
|    | Delay Calculation                             |
|    | Flip-Flop and Latch Timing Checks             |
|    | Timing Analysis in the Design Flow            |
|    | Synopsys Design Constraint (SDC) Commands     |
|    | Library Timing Data                           |
|    | Design Compiler                               |
|    | Ideal Clocking                                |
|    | Wire Load Models and Topographical Technology |
|    | Design Partitioning                           |
|    | Path Groups                                   |
|    | Register Retiming Optimization                |
|    | IC Compiler                                   |
|    | Placement                                     |
|    | Clock Tree Synthesis                          |
|    | Routing                                       |

|    | Timing Analysis After Routing                     | 1-39       |
|----|---------------------------------------------------|------------|
|    | Synthesis Design Rules                            | 1-40       |
| 2. | Clocks                                            |            |
|    | Creating Clocks                                   | 2-2        |
|    | Clock Network Effects                             | 2-3        |
|    | Clock Latency                                     | 2-5        |
|    | Propagated Latency                                | 2-5<br>2-6 |
|    | Ideal Network Latency                             | 2-0<br>2-7 |
|    | Clock Uncertainty.                                | 2-8        |
|    | Ideal Clock Transition Times                      | 2-11       |
|    | Reporting Clock Information                       | 2-12       |
|    | Multiple Clocks                                   | 2-12       |
|    | Synchronous Clocks                                | 2-14       |
|    | Asynchronous Clocks                               | 2-16       |
|    | Exclusive Clocks                                  | 2-16       |
|    | Clock Sense                                       | 2-18       |
|    | Pulse Clocks                                      | 2-22       |
|    | Clock-Gating Signal Timing Checks                 | 2-24       |
|    | Generated Clocks                                  | 2-29       |
|    | Divide-by-2 Generated Clock                       | 2-30       |
|    | Generated Clock Based on Edges                    | 2-30       |
|    | Divide-by Clock Based on Falling Edges            | 2-31       |
|    | Shifting the Edges of a Generated Clock           | 2-33       |
|    | Combinational-Only Source Latency Calculation     | 2-34       |
|    | Generated Clock Based on a Non-Unate Master Clock | 2-35       |
|    | Estimated I/O Latency                             | 2-37       |
|    | Calculating I/O Latency for Input Paths           | 2-39       |
|    | Calculating I/O Latency for Output Paths          | 2-40       |
|    | Propagated Clocks                                 | 2-40       |
| 3. | Timing Paths                                      |            |
|    | Path Groups                                       | 3-2        |

4.

| User Grouping of Paths                               | 3-2          |
|------------------------------------------------------|--------------|
| Weight or Cost Function                              | 3-2          |
| Critical Range                                       | 3-3          |
| Reporting Path Groups                                | 3-3          |
| Path Specification Methods                           | 3-4          |
| Through Arguments                                    | 3-5          |
| Rise/Fall From/To Clock                              | 3-6          |
| Default Path Delay Constraints                       | 3-9          |
| Path Delay for Flip-Flops Using a Single Clock       | 3-9          |
| Path Delay for Flip-Flops Using Different Clocks     | 3-11         |
| Setup Analysis                                       | 3-12         |
| Hold Analysis                                        | 3-12         |
| Single-Cycle Path Analysis Examples                  | 3-13         |
| Timing Exceptions                                    | 3-15         |
| False Path Exceptions                                | 3-16         |
| Maximum and Minimum Path Delay Exceptions            | 3-17         |
| Multicycle Path Exceptions                           | 3-18         |
| Specifying Exceptions Efficiently                    | 3-23         |
| Exception Order of Precedence                        | 3-25<br>3-25 |
| Path Specification Priority                          | 3-25         |
| Reporting Exceptions                                 | 3-27         |
| Removing Exceptions                                  | 3-27         |
| Data-to-Data Checks                                  | 3-28         |
| Specifying Data-to-Data Checks                       | 3-29         |
| Generating Timing Reports for Data Checks            | 3-31         |
| Data Checks and Clock Domains                        | 3-32         |
| Library-Based Data Checks                            | 3-32         |
| · · · <b>,</b> · · · · · · · · · · · · · · · · · · · |              |
| Operating Conditions                                 |              |
| Operating Condition Definitions                      | 4-2          |
| Setting Operating Conditions                         | 4-4          |
| Operating Condition Modes                            | 4-5          |
| Minimum and Maximum Delay Calculations               | 4-7          |
| Min-Max Cell and Net Delay Values                    | 4-7          |

|    | Setup and Hold Checks  Path Delay Tracing for Setup and Hold Checks  Setup Timing Check for Worst-Case Conditions  Hold Timing Check for Best-Case Conditions.  Simultaneous Best-Case/Worst-Case Conditions  Path Tracing in On-Chip Variation Mode | 4-8<br>4-9<br>4-9<br>4-10<br>4-11            |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
|    | Using Two Libraries for Min-Max Analysis                                                                                                                                                                                                             | 4-12                                         |
|    | Setting Derating Factors                                                                                                                                                                                                                             | 4-12                                         |
|    | Voltage and Temperature Scaling Between Libraries                                                                                                                                                                                                    | 4-15                                         |
|    | Clock Reconvergence Pessimism Removal On-Chip Variation Example Reconvergent Logic Example Setting Clock Reconvergence Pessimism Removal Transparent Latch Edge Considerations Reporting CRPR Calculations                                           | 4-16<br>4-16<br>4-17<br>4-18<br>4-20<br>4-21 |
| 5. | Timing Constraints                                                                                                                                                                                                                                   |                                              |
|    | Input Delays                                                                                                                                                                                                                                         | 5-2<br>5-5                                   |
|    | Output Delays                                                                                                                                                                                                                                        | 5-5                                          |
|    | Drive Characteristics at Input Ports  Setting the Port Driving Cell.  Setting the Port Drive Resistance  Setting a Fixed Port Transition Time  Removing Drive Information From Ports                                                                 | 5-6<br>5-7<br>5-9<br>5-10<br>5-11            |
|    | Port Load Capacitance                                                                                                                                                                                                                                | 5-11                                         |
|    | Ideal Networks Propagation of the Ideal Network Property Creating Ideal Networks Removing Ideal Networks Reporting Ideal Networks Retrieving Ideal Objects. Setting Ideal Latency and Ideal Transition Time                                          | 5-12<br>5-13<br>5-14<br>5-16<br>5-16<br>5-17 |
|    | Case Analysis                                                                                                                                                                                                                                        | 5-18                                         |

6.

| Reporting Case Analysis                             | 5-20 |
|-----------------------------------------------------|------|
| Removing Case Analysis                              | 5-21 |
| Constant Propagation Log File                       | 5-21 |
| Usage Example                                       | 5-23 |
| Mode Analysis                                       | 5-23 |
| Mode Groups                                         | 5-23 |
| Setting Modes Using Case Analysis                   | 5-24 |
| Setting Modes Directly on Cells                     | 5-25 |
| Reporting Modes                                     | 5-26 |
| Wire Load Models                                    | 5-26 |
| Net Capacitance, Resistance, and Area Calculation   | 5-27 |
| Choosing a Wire Load Model                          | 5-28 |
| Wire Load Model Modes                               | 5-29 |
| Setting a Wire Load Model                           | 5-31 |
| Local Link Library Usage                            | 5-31 |
| Setting a Wire Load Selection Group                 | 5-32 |
| Wire Load Models for Hierarchical Cells             | 5-32 |
| Selecting the Wire Load Model Automatically         | 5-33 |
| Defining the Minimum Block Size                     | 5-33 |
| Reporting Wire Load Models                          | 5-34 |
| Timing Loops                                        | 5-36 |
| Breaking Feedback Loops Manually                    | 5-37 |
|                                                     |      |
| Back-Annotation                                     |      |
| Back-Annotating Delays and Timing Checks            | 6-2  |
| Delay Calculations                                  | 6-2  |
| Back-Annotating Timing Information from an SDF File | 6-3  |
| Instance Names                                      | 6-3  |
| Cell and Pin Names                                  | 6-3  |
| DESIGN Field Names                                  | 6-4  |
| Supported SDF Constructs                            | 6-4  |
| Back-Annotating Timing From a Subdesign Timing File | 6-9  |
| Back-Annotating Load Delay                          | 6-9  |
| Back-Annotating for Worst Timing Delay              | 6-9  |
| Back-Annotating Timing Checks                       | 6-9  |
| Back-Annotating for Conditional Arc Cell Delay      | 6-10 |

|    | Reading SDF Instance Names                                | 6-10         |
|----|-----------------------------------------------------------|--------------|
|    | Back-Annotation Order of Precedence                       | 6-11         |
|    | Examples                                                  | 6-12         |
|    | Writing an SDF File                                       | 6-12         |
|    | Annotating Delays and Timing Checks From The Command Line | 6-12         |
|    | Defining Net and Cell Delays                              | 6-13         |
|    | Defining Timing Check Values Between Pins                 | 6-15         |
|    | Reporting Annotated Values and Checks                     | 6-16         |
|    | Reporting Load and Resistance Values                      | 6-16         |
|    | Reporting Annotated Delay Values                          | 6-17         |
|    | Removing Back-Annotated Values                            | 6-19<br>6-19 |
|    | Removing Annotated Delay Values                           | 6-19         |
|    | Removing Annotated Resistance or Capacitance Values       | 6-21         |
|    | Removing Back-Annotated Values Command Summary            | 6-22         |
|    | Back-Annotating Net Load                                  | 6-22         |
|    | Back-Annotating Net Resistance                            | 6-24         |
|    | Back-Annotating Detailed Parasitics                       | 6-25         |
|    | RTL Load Annotation with Wire Load Modeling               | 6-27         |
|    | Default Resistance Values                                 | 6-30         |
|    | RTL Load Buffering                                        | 6-30         |
|    | Extracting RTL Loads From Placement                       | 6-30         |
|    | Extraction of set_rtl_load                                | 6-30         |
| 7. | Timing Reports                                            |              |
|    | Reporting Commands                                        | 7-2          |
|    | check_timing Command                                      | 7-5          |
|    | report_constraint Command                                 | 7-7          |
|    | report_timing Command                                     | 7-10         |
|    | report_timing Report Contents                             | 7-10         |
|    | report_timing Command Options                             | 7-13         |
|    | Scope of the Design Reported                              | 7-14         |
|    | Path Details Reported                                     | 7-14         |
|    | Delay Type (Min/Max) Reported                             | 7-17         |
|    | Number of Paths Reported                                  | 7-17         |
|    | Other Options                                             | 7-18         |

|    | report_delay_calculation Command                                                                                                                                                                  | 7-18                                                 |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
|    | get_timing_paths Command                                                                                                                                                                          | 7-19                                                 |
|    | report_clock_timing Command  Latency and Transition Time Reporting  Skew Reporting  Interclock Skew Reporting  Clock Timing Reporting Options  Summary Report  List Report  Verbose (Path) Report | 7-22<br>7-22<br>7-25<br>7-25<br>7-26<br>7-26<br>7-28 |
| 8. | Graphical User Interface                                                                                                                                                                          |                                                      |
|    | Using the GUI for Timing Analysis                                                                                                                                                                 | 8-2<br>8-5<br>8-6                                    |
|    | Path Slack Histogram                                                                                                                                                                              | 8-7                                                  |
|    | Path Inspector Path Schematic Path Element Tables Path Delay Profiles                                                                                                                             | 8-9<br>8-12<br>8-13<br>8-14                          |
|    | Timing Analysis Driver                                                                                                                                                                            | 8-16                                                 |
| 9. | Timing in Latch-Based Designs                                                                                                                                                                     |                                                      |
|    | Time Borrowing in Latch-Based Designs  A Simple D Latch                                                                                                                                           | 9-2<br>9-2<br>9-3<br>9-5<br>9-5<br>9-5               |
|    | Constraining a Latch-Based Design  Creating Non-Overlapping Clocks  What Are Two-Phase Designs?  What Are Non-Overlapping Clocks?                                                                 | 9-11<br>9-12<br>9-12<br>9-12                         |
|    | Path Timing Report With Borrowing                                                                                                                                                                 | 9-13                                                 |

Contents ix

| Latch-Based Time-Borrowing Example                 | 9-17 |
|----------------------------------------------------|------|
| Linear Block Encoder and Decoder                   | 9-17 |
| Noisy Channel                                      | 9-18 |
| Linear Block Decoder for Single-Bit Error          | 9-18 |
| Linear Block Encoder and Decoder Implementation    | 9-19 |
| VHDL Code                                          | 9-19 |
| Setting Constraints on the Linear Block Encoder    | 9-24 |
| report_timing Command Output                       | 9-2  |
| Appendix A. Static Timing Delay Calculation        |      |
| Path-Based Timing Optimization                     | A-2  |
| Reporting Retain Arcs                              | A-3  |
| Reporting Arc Delay Calculations                   | A-4  |
| Debugging Delay Calculations Along a Critical Path | A-   |
| Reporting Details of a Cell Delay Arc              | A-(  |
| Delay Models                                       | A-   |
| Linear Delay Model                                 | A-   |
| Slope Delay (D <sub>S</sub> )                      | A-1  |
| Intrinsic Delay (D <sub>I</sub> )                  | A-1  |
| Transition Time ( $D_T$ )                          | A-1  |
| Connect Delay (D <sub>C</sub> )                    | A-1  |
| Delay Calculation (Linear) Example                 | A-1  |
| CMOS2 Delay Model                                  | A-1  |
| Edge Rate Delay (D <sub>E</sub> )                  | A-1  |
| Intrinsic Delay (D <sub>I</sub> )                  | A-1  |
| Transition Time ( $D_T$ )                          | A-1  |
| Connect Delay (D <sub>C</sub> )                    | A-1  |
| Delay Calculation (CMOS2) Example                  | A-2  |
| Nonlinear Delay Model                              | A-2  |
| Library Cell Timing Arcs                           | A-2  |
| Delay Calculation Example                          | A-2  |
| Environmental Scaling                              | A-2  |

Index

Contents x

# Preface

This preface includes the following sections:

- What's New in This Release
- About This Manual
- Customer Support

#### What's New in This Release

Information about new features, enhancements, and changes, along with known problems and limitations and resolved Synopsys Technical Action Requests (STARs), is available in the *Design Compiler Release Notes* and *IC Compiler Release Notes* in SolvNet.

To see the Design Compiler Release Notes or IC Compiler Release Notes,

1. Go to the Download Center on SolvNet located at the following address:

https://solvnet.synopsys.com/DownloadCenter

If prompted, enter your user name and password. If you do not have a Synopsys user name and password, follow the instructions to register with SolvNet.

2. Select Design Compiler or IC Compiler, and then select a release in the list that appears.

#### **About This Manual**

The Synopsys Timing Constraints and Optimization User Guide describes the usage of timing constraints and timing analysis in Design Compiler and IC Compiler for the synthesis, optimization, and physical implementation of integrated circuits. Most of the information in this book applies to both Design Compiler and IC Compiler, and much of it applies to PrimeTime as well. Some information applies to only Design Compiler or only IC Compiler, as noted in the text.

#### **Audience**

This manual is intended for logic designers and engineers who use the Synopsys synthesis and physical implementation tools to design ASICs, ICs, and FPGAs. Readers should already be familiar with UNIX or Linux and basic IC design principles.

#### **Related Publications**

For additional information about Design Compiler and IC Compiler, see Documentation on the Web, which is available through SolvNet at the following address:

https://solvnet.synopsys.com/DocsOnWeb

You might also want to refer to the documentation for the following related Synopsys products:

- · Design Vision
- DesignWare components
- DFT Compiler
- HDL Compiler
- Milkyway Environment
- PrimeTime
- Power Compiler

Also see the following related document:

• Using Tcl With Synopsys Tools

# **Conventions**

The following conventions are used in Synopsys documentation.

| Convention     | Description                                                                                                                                                                                                                                      |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Courier        | Indicates command syntax.                                                                                                                                                                                                                        |
| Courier italic | Indicates a user-defined value in Synopsys syntax, such as <code>object_name</code> . (A user-defined value that is not Synopsys syntax, such as a user-defined value in a Verilog or VHDL statement, is indicated by regular text font italic.) |
| Courier bold   | Indicates user input—text you type verbatim—in Synopsys syntax and examples. (User input that is not Synopsys syntax, such as a user name or password you enter in a GUI, is indicated by regular text font bold.)                               |
| []             | Denotes optional parameters, such as pin1 [pin2 pinN]                                                                                                                                                                                            |
| I              | Indicates a choice among alternatives, such as low   medium   high (This example indicates that you can enter one of three possible values for an option: low, medium, or high.)                                                                 |
| _              | Connects terms that are read as a single term by the system, such as set_annotated_delay                                                                                                                                                         |
| Control-c      | Indicates a keyboard combination, such as holding down the Control key and pressing c.                                                                                                                                                           |
| \              | Indicates a continuation of a command line.                                                                                                                                                                                                      |
| 1              | Indicates levels of directory structure.                                                                                                                                                                                                         |
| Edit > Copy    | Indicates a path to a menu command, such as opening the Edit menu and choosing Copy.                                                                                                                                                             |

## **Customer Support**

Customer support is available through SolvNet online customer support and through contacting the Synopsys Technical Support Center.

### **Accessing SolvNet**

SolvNet includes an electronic knowledge base of technical articles and answers to frequently asked questions about Synopsys tools. SolvNet also gives you access to a wide range of Synopsys online services including software downloads, documentation on the Web, and "Enter a Call to the Support Center."

To access SolvNet, go to the SolvNet Web page at the following address:

#### https://solvnet.synopsys.com

If prompted, enter your user name and password. If you do not have a Synopsys user name and password, follow the instructions to register with SolvNet.

If you need help using SolvNet, click HELP in the top-right menu bar or in the footer.

### Contacting the Synopsys Technical Support Center

If you have problems, questions, or suggestions, you can contact the Synopsys Technical Support Center in the following ways:

- Open a call to your local support center from the Web by going to http:// solvnet.synopsys.com (Synopsys user name and password required), and then clicking "Enter a Call to the Support Center."
- Send an e-mail message to your local support center.
  - E-mail support center@synopsys.com from within North America.
  - Find other local support center e-mail addresses at http://www.synopsys.com/Support/GlobalSupportCenters/Pages
- Telephone your local support center.
  - Call (800) 245-8005 from within the continental United States.
  - Call (650) 584-4200 from Canada.
  - Find other local support center telephone numbers at http://www.synopsys.com/Support/GlobalSupportCenters/Pages

1

# Introduction to Synthesis Timing

Timing is a major consideration in the synthesis and physical implementation of synchronous digital circuits. Design Compiler and IC Compiler perform static timing analysis to drive the selection of logic gates, the implementation of logic, the placement of logic cells, and the routing of interconnections. Using a sign-off timing analysis tool such as PrimeTime is necessary to verify that the completed design will work at the intended clock speed. All of these tools share some of the same timing analysis commands and operating principles, as described in the following sections:

- Static Timing Analysis
- Timing Analysis in the Design Flow
- Synthesis Design Rules

# **Static Timing Analysis**

Static timing analysis is a method of validating the timing performance of a design by checking all possible paths for timing violations under worst-case conditions. It considers the worst possible delay through each logic element, but not the logical operation of the circuit.

In comparison to circuit simulation, static timing analysis is faster and more thorough. It is faster because it does not need to simulate multiple test vectors. It is more thorough because it checks the worst-case timing for all possible logic conditions, not just those sensitized by a particular set of test vectors. However, static timing analysis checks the design only for proper timing, not for correct logical functionality.

Timing, area, and power constraints drive the operation of synthesis with Design Compiler and physical implementation with IC Compiler. These tools synthesize the netlist and perform physical placement and routing with the goal of making the fastest device, using the least area and power, in the shortest turnaround time that is consistent with the design requirements. These tools perform trade-offs between speed, area, power, and runtime according to the constraints set by the designer. However, a chip must meet the timing constraints in order to operate at the intended clock rate, so timing is the most important design constraint.

Static timing analysis seeks to answer the question, "Will the correct data be present at the data input of each synchronous device when the clock edge arrives, under all possible conditions?" This concept is illustrated by the circuit in Figure 1-1 and the timing diagram in Figure 1-2.

Figure 1-1 Timing Path Example



In Figure 1-1, the dashed arrow represents a timing path. The change in signal data caused by a clock transition at flip-flop FF1 must be propagated to flip-flop FF2 before the following clock edge arrives at FF2, so that the logically processed data can be reliably latched into

FF2. The change at FF1.Q might affect the output of the combinational logic cloud at FF2.D, depending on the logic itself, the data value, and the values of any side inputs feeding into the logic. The change at FF2.D, if any, must occur before the next clock edge arriving at FF2.

Figure 1-2 Setup Check Timing



Figure 1-2 shows the timing for this path. The arrival of a clock edge at FF1 latches the data at the input FF1.D into the flip-flop. It also places that data on the flip-flop output, FF1.Q, after the clock-to-Q delay of the flip-flop. This is called the *launch* event for the timing path.

This signal goes through the combinational logic with some delay. The output of the combinational logic is at the input of the second flip-flop, FF2.D. The time at which the signal value changes here is called the *arrival time* for the path.

The change in value at FF2.D must occur before the arrival of the clock edge arriving at FF2, by at least an amount equal to the setup time requirement for the flip-flop. This latest allowable arrival time is called the *required time* for the path. The latching of data at FF2 is called the *capture* event for the timing path. In this example, the capture event occurs one whole clock cycle after the launch event.

The amount of time by which the timing constraint is met is called the *slack* of the timing check. If the signal arrives earlier than necessary as shown in Figure 1-2, the slack is positive. If the signal arrives exactly at the required time, the slack is zero and the timing constraint is barely met. If the signal arrives later than the required time, the slack is negative. In all three cases, the amount of slack is the required time minus the arrival time. For example, if the required time is 1.8 ns after the launch clock edge and the arrival time is 1.6 ns after the launch clock edge, the slack is 1.8 minus 1.6, or 0.2 ns, a positive number.

The foregoing timing check is called a *setup* check, which verifies that a change in data arrives soon enough before each clock edge at the sequential device. This is the most common type of timing check that drives synthesis and optimization. However, other types of timing checks can be performed as well.

For example, a *hold* check verifies that the data remains valid during and after the arrival of the clock edge at the end of the path by a sufficient amount. A hold violation can occur if the shortest possible combinational delay from launch to capture is very short and the longest delay from the launch clock edge to the capture clock edge is very long. An example is shown in Figure 1-3 and Figure 1-4.

Figure 1-3 Hold Check Timing Path Example



In Figure 1-3, the timing path has a very short combinational delay from FF1 to FF2, consisting of a single NAND gate. Meanwhile, there is a long delay for the clock signal between the two flip-flops because of the three buffers, possibly made even longer by a large RC delay due to a long route. Therefore, the capture clock signal CLK2 arriving at FF2 is significantly delayed with respect to the launch clock CLK1 at FF1.



Figure 1-4 Hold Check Timing

Figure 1-4 shows the possible timing in this situation. The setup constraint is met easily because the data arrives well before the required setup time. However, the hold constraint is not met because the data at the D input of FF2 is not held long enough after the nominal clock arrival time. The data changes before the delayed clock CLK2 has a chance to latch it in. This type of violation can be fixed by shortening the delay in the clock line or by increasing the delay in the data path.

By default, the synthesis or implementation tool fixes setup violations, but not hold violations, because setup requirements are more difficult to satisfy. To have the tool fix hold violations as well as setup violations, use the  $set_fix_hold$  command. This command sets the  $fix_hold$  attribute on specified clocks, which directs the tool to check for and fix hold violations during the compile operation.

Each type of timing check considers different worst-case conditions. For example, a setup check considers the longest and slowest possible path through the combinational logic of the data path and the earliest possible arrival of the capture clock edge with respect to the

launch clock edge. Conversely, a hold check considers the shortest and fastest possible path through the combinational logic of the data path and the latest possible arrival of the capture clock edge with respect to the launch clock edge.

Figure 1-5 shows examples of different pathways that can be taken through the same block of combinational logic. In a data path, a setup check would consider the longer delay through three gates, whereas a hold check would consider the shorter path through two gates.

Figure 1-5 Multiple Paths Through Combinational Logic



A synthesis, optimization, or analysis tool can perform timing checks on the following types of paths:

- Clock path (a path from a clock input port or cell pin, through one or more buffers or inverters, to the clock pin of a sequential element) for data setup and hold checks
- Clock-gating path (a path from an input port to a clock-gating element) for clock-gating setup and hold checks
- Asynchronous path (a path from an input port to an asynchronous set or clear pin of a sequential element) for recovery and removal checks
- Data-to-data check (a custom timing check specified with the set\_data\_check command, having specified setup and hold times between data signals)

Some of these path types are shown in Figure 1-6.

Figure 1-6 Path Types



A tool can also perform timing checks on the asynchronous preset and clear inputs of sequential devices. A *recovery* check verifies that enough time has passed after the inactivation of an asynchronous control signal before a clock edge occurs. A *removal* check verifies that enough time has passed after a clock edge before the removal of an asynchronous control signal. These types of checking are enabled by setting the enable recovery removal arcs variable to true.

A *clock-gating* check is a setup or hold check performed on the control input of a clock-gating cell. This type of check detects occurrences of clipped clocked edges or spurious clock pulses. The command for specifying clock-gating checks is set\_clock\_gating\_check.

# **Timing Paths**

The timing analysis tool finds and analyzes all of the timing paths in the design. Each path has a startpoint and an endpoint. The startpoint is a place in the design where data is launched by a clock edge. The data is propagated through combinational logic in the path and then captured at the endpoint by another clock edge.

The startpoint of a path is a clock pin of a sequential element or an input port of the design. The arrival of an active clock edge at a startpoint launches data through the path. An input port can be considered a startpoint due to the arrival of data launched by an external source.

The endpoint of a path is a data input pin of a sequential element or an output port of the design. The arrival of an active clock edge at the clock input of the capture device captures data at the end of the path. An output port can be considered an endpoint due to the external capture of the data leaving the output port.

Figure 1-7 shows an example of a design and its timing paths.

Figure 1-7 Timing Path Types



Each path starts at a data launch point, passes through some combinational logic, and ends at a data capture point:

- Path 1 starts at an input port and ends at the data input of a sequential element.
- Path 2 starts at the clock pin of a sequential element and ends at the data input of a sequential element.
- Path 3 starts at the clock pin of a sequential element and ends at an output port.
- Path 4 starts at an input port and ends at an output port.

Each path in the design has an associated timing slack. The slack is a time value that can be positive, zero, or negative. The single path having the worst slack is called the *critical path*. This is the path that has the most negative slack, or if there are no timing violations, the one with the smallest slack among all paths in the design. The plural term, *critical paths*, means the set of *n* paths having the worst slack among all paths in the design.

You can optionally divide the paths of a design into groups so that timing analysis, reporting, and optimization are done separately for the designated *path groups*. For example, you might put the input-to-register, register-to-register, and register-to-output paths into three separate groups because they have different types of timing constraints. By default, there is one path group for each clock used in the design.

The following is a typical path timing report generated by the report\_timing command in IC Compiler. A similar report is produced by the report\_timing command in Design Compiler or PrimeTime.

Startpoint: I\_RISC\_CORE/I\_INSTRN\_LAT/Instrn\_1\_reg\_27\_

(rising edge-triggered flip-flop clocked by SYS\_2x\_CLK)

Endpoint: I\_RISC\_CORE/I\_ALU/Zro\_Flag\_reg

(rising edge-triggered flip-flop clocked by SYS\_2x\_CLK)

Path Group: SYS\_2x\_CLK

Path Type: max

| Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Incr                                                                                                                         |                                       | Path                                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------------------------------------|
| clock SYS_2x_CLK (rise edge) clock network delay (propagated) I_RISC_CORE/I_INSTRN_LAT/Instrn_1_reg_27_/CP (senrq1) I_RISC_CORE/I_INSTRN_LAT/Instrn_1_reg_27_/Q (senrq1) I_RISC_CORE/I_INSTRN_LAT/Instrn_1[27] (INSTRN_LAT) I_RISC_CORE/I_ALU/ALU_OP[3] (ALU) I_RISC_CORE/I_ALU/U288/ZN (nr03d0) I_RISC_CORE/I_ALU/U261/ZN (nd03d0) I_RISC_CORE/I_ALU/U307/ZN (invbd2) I_RISC_CORE/I_ALU/U344/ZN (nr02d1) I_RISC_CORE/I_ALU/U344/ZN (nr02d0) I_RISC_CORE/I_ALU/U348/ZN (nd03d0) I_RISC_CORE/I_ALU/U355/ZN (nr03d0) I_RISC_CORE/I_ALU/U38/Z (an02d1) I_RISC_CORE/I_ALU/U40/Z (an02d1) I_RISC_CORE/I_ALU/U40/Z (an02d1) I_RISC_CORE/I_ALU/U48/ZN (nd02d1) I_RISC_CORE/I_ALU/U48/ZN (nd02d1) I_RISC_CORE/I_ALU/U27/ZN (nd02d1) I_RISC_CORE/I_ALU/U27/ZN (nd02d1) I_RISC_CORE/I_ALU/U27/ZN (nd02d1) I_RISC_CORE/I_ALU/Zro_Flag_reg/D (secrq4) data arrival time | 0.00<br>0.51<br>0.00<br>0.62<br>0.00<br>0.36<br>0.94<br>0.35<br>0.16<br>0.11<br>0.28<br>0.29<br>0.15<br>0.12<br>0.06<br>0.06 | * * * * * * * * * * * * * * * * * * * | 0.51<br>0.51 r<br>1.13 f                           |
| <pre>clock SYS_2x_CLK (rise edge) clock network delay (propagated) clock uncertainty I_RISC_CORE/I_ALU/Zro_Flag_reg/CP (secrq4) library setup time data required time</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 4.00<br>0.47<br>-0.10<br>0.00<br>-0.37                                                                                       |                                       | 4.00<br>4.47<br>4.37<br>4.37 r<br>4.00<br>4.00<br> |
| slack (MET)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                              |                                       | 0.01                                               |

By default, the report\_timing command reports the worst setup path in each path group. In this example, the logic associated with the reported path is shown in Figure 1-8.

Figure 1-8 Timing Path Logic



The report starts by showing the path startpoint, path endpoint, path group name, and path timing check type. In this example, the path timing check type is shown as "max," which means a maximum-delay or setup check; "min" would mean a minimum-delay or hold check.

A large table shows point-by-point accounting of the delays along the path from the startpoint to the endpoint. The table has columns labeled Point, Incr, and Path. These columns list the points (cell pins) along the path, the incremental contribution to the delay at each point, and the cumulative delay up to that point, respectively. Hierarchical boundary crossings are listed as well, showing zero incremental delay at each crossing.

The asterisk (\*) symbols in the Incr column indicate where SDF back-annotated delay values were used for the net delay. The letters "r" and "f" in the Path column indicate the sense of the signal transition, either rising or falling, at that point in the path.

The path starts with the launch clock edge and ends at the data input of the capture device. The "data arrival time" shown in the table is the amount of elapsed time from the source of the launch clock edge to the arrival of data at the endpoint, taking into consideration the longest possible delays along the path.

After this is the accounting for the required arrival time. The "data required time" shown in the table is the latest allowable arrival time for the data at the path endpoint, taking into account the nominal capture clock edge time, the clock network delay, the clock uncertainty,

the least possible delay along the clock path, and the library setup time requirement for the capture device. The required time is subject to adjustment for clock reconvergence pessimism removal (CRPR).

The slack value shown at the end of the report is simply the data required time minus the data arrival time. The slack is the amount of time by which the timing constraint is met, considering the latest possible arrival of data at the endpoint and the earliest possible arrival of the capture clock edge.

In this example, the slack is a very small positive value, which means that the timing constraint is barely met. A negative slack would require a change in the design to fix the violation. For example, a driver in the path could be replaced with a larger cell with a higher drive strength, which would reduce the net delay. On the other hand, a large positive slack would offer opportunities for optimization. For example, drivers in the path could be replaced with slower, smaller cells to reduce the area or with slower, higher-threshold cells to reduce leakage power.

#### Clocks

To perform timing analysis, you must specify the period of the clock or clocks used in the design and possibly the transition time, waveform, latency, uncertainty, relative skew, and other timing characteristics, as shown in Figure 1-9. The timing analysis takes all of these clock characteristics into account to determine the worst possible conditions for each type of timing check. The command for specifying clocks is <code>create\_clock</code>.

Figure 1-9 Clock Characteristics



If multiple clocks are used in the design, you must specify the timing relationships between those clocks so that the analysis tool can check the timing of a path launched by one clock and captured by another. By default, the tool assumes that after the occurrence of a launch event at a path startpoint, the very next clock edge that can occur at the path endpoint should capture the data at the end of the path. Any exceptions to this basic assumption must be specified as *timing exceptions*. Some examples of timing exceptions are *false paths*, *multicycle paths*, and explicit *minimum-delay paths* and *maximum-delay paths*:

- A false path is a path that physically exists in the design but never propagates data from the startpoint to the endpoint due to the logic configuration, expected data sequence, or operating mode.
- A *multicycle path* is a path designed to take more than one clock cycle from launch to capture.
- A minimum-delay path or maximum-delay path is a path that must meet a delay constraint that you specify explicitly as a time value.

A clock signal typically has a very large fanout to many sequential devices. Therefore, each clock is usually implemented as a branching tree of buffers organized in a multilevel hierarchy. Clock tree synthesis is typically performed at the placement and routing stage, not at the logic synthesis stage, because placement and routing provide the interconnect length information needed to build the tree. To perform timing analysis before clock tree synthesis and layout, the logic synthesis tool must estimate the delays from the clock source to the clock pins of sequential devices.

# **Input and Output Delays**

The analysis tool determines the timing slack for a path by comparing the startpoint-to-endpoint delay with the time span between the launch and capture clock edges. However, for a path starting at an input to the design, the arrival time of the data cannot be determined from the design netlist. This is because the external launch time and logic delays are unknown. Therefore, in order to analyze the input-to-register timing, you must specify the external timing conditions leading up to the input as an input delay. This concept is illustrated in Figure 1-10.

Figure 1-10 External Input Delay



The design being analyzed is enclosed in the dashed rectangle. The data arriving at input port "A" is launched by an external sequential device clocked by CLK. Then the data passes through some combinational logic before reaching input "A." To analyze the timing of Path 1, you need to specify the amount of delay from the clock edge to the arrival of data at input "A." In this example, the input delay is the CLK-to-Q delay of the external flip-flop plus the delay of the external buffer. You can also specify the drive characteristics of the external buffer for a more accurate calculation of the interconnect delay from input "A" to the combinational logic inside the design.

Similarly, for a path ending at an output of the design, the capture time of the data cannot be determined from the design netlist. This is because the capture time and external logic delays are unknown. Therefore, in order to analyze the register-to-output timing, you must specify the external timing conditions beyond the output as an output delay. This concept is illustrated in Figure 1-11.

Path 3

Logic

D

Logic

D

CLK

Logic

CLK

Logic

Logic

D

CLK

CLK

Figure 1-11 External Output Delay

The data leaving at output port "Z" passes through some combinational logic and is captured by an external sequential device clocked by CLK. To analyze the timing of Path 3, you need to specify the amount of delay from the arrival of data at output "Z" to the capture clock edge. In this example, the output delay is the delay of the external buffer plus the setup time requirement for the external flip-flop. You should also specify the load characteristics of the external circuit to accurately account for the interconnect delay at the output "Z."

The commands for specifying input delays and output delays are set\_input\_delay and set\_output\_delay.

# **Delay Calculation**

To find the slack for a timing path, the analysis tool must determine the arrival time of the launch clock edge, the arrival time of the capture clock edge, and the delay from the startpoint to the endpoint of the path. To find the arrival time of the launch clock edge, the tool calculates the delay from the original source clock to the clock input of the launch flipflop. Similarly, to find the arrival time of the capture clock edge, the tool calculates the delay from the original source clock to the clock input of the capture flip-flop. It also considers the period of the clock, or if the launch and capture clocks are different, the worst-case offset between those clocks.

To find the cumulative delay along a path, the analysis tool adds the individual cell delays and interconnect delays along the path. The cell delay information is contained in the library description of each cell. To calculate the interconnect delays, the analysis tool needs to know the characteristics of the driver cell that is driving the net, the load characteristics of

the receiver cells driven by the net, and the resistance and capacitance (RC) characteristics of the wires in the net. The interconnect RC characteristics depend on the physical configuration and lengths of the wires, so these characteristics can be determined accurately only after layout has been completed.

For timing analysis performed before placement and routing, the analysis tool must estimate the wire delays. The simplest estimation method is the wire load model, which gets a rough value for the total wire capacitance based on the size of the chip and the fanout of the net. Larger chip sizes and larger fanouts are assumed to result in longer wires and more resistance and capacitance. More advanced wire estimation methods predict cell placement and wire lengths, thereby getting more accurate results without using wire load models. Design Compiler with topographical technology is one such advanced tool.

For timing analysis performed after placement and routing, the analysis tool can extract the RC network accurately from the physical lengths of the wire connections and the known characteristics of the wire material. IC Compiler, for example, extracts RC information accurately from detail routing when available or from global routing where detail routing has not been completed.

The main types of information used in delay calculation are summarized in Figure 1-12.



Figure 1-12 Information Used in Cell and Net Delay Calculation

You can view a detailed accounting of the delay calculation for a cell or a net by using the report\_delay\_calculation command.

## Flip-Flop and Latch Timing Checks

The method of checking setup and hold timing differs somewhat between flip-flop and latch-based designs. For edge-sensitive flip-flops, the data must be available strictly at the time that the clock edge arrives at the flip-flop. For level-sensitive latches, "borrowing" time from one latch to the next can loosen the timing requirements for certain paths.

Figure 1-13 shows how a timing analysis tool checks setup and hold constraints for a synchronous design based on flip-flops.

Figure 1-13 Setup and Hold Checks



For this example, assume that the flip-flops are defined in the technology library to have a minimum setup time of 1.0 time units and a minimum hold time of 0.0 time units. The clock period is defined by the <code>create\_clock</code> command to be 10 time units. The time unit size, such as ns or ps, is specified in the technology library.

By default, the tool assumes that the signal is to be propagated through the path in one clock cycle. When the tool performs a setup check, it verifies that the data launched from FF1 reaches FF2 within one clock cycle and arrives at least 1.0 time unit before the data gets captured by the next clock edge at FF2. If the path delay is too long, it is reported as a timing violation. For this setup check, the tool considers the longest possible delay along the data path and the shortest possible delay along the clock path between FF1 and FF2.

When the tool performs a hold check, it verifies that the data launched from FF1 reaches FF2 no sooner than the capture clock edge for the previous clock cycle. This check ensures that the data that already exists at the input of FF2 remains stable long enough after the clock edge that captures data for the previous cycle. For this hold check, the tool considers the shortest possible delay along the data path and the longest possible delay along the clock path between FF1 and FF2. A hold violation can occur if the clock path has a long delay.

Latch-based designs typically use two-phase, nonoverlapping clocks to control successive registers in a data path. In these cases, the tool can use time borrowing to lessen the constraints on successive paths.

For example, consider the two-phase, latch-based path shown in Figure 1-14. All three latches are level-sensitive, with the gate active when the G input is high. L1 and L3 are controlled by PH1, and L2 is controlled by PH2. A rising edge launches data from the latch output, and a falling edge captures data at the latch input. For this example, consider the latch setup and delay times to be zero.

Figure 1-14 Latch-Based Paths



Figure 1-15 shows how the tool performs setup checks between these latches. For the path from L1 to L2, the rising edge of PH1 launches the data. The data must arrive at L2 before the closing edge of PH2 at time = 20. This timing requirement is labeled Setup 1. Depending on the amount of delay between L1 and L2, the data might arrive either before or after the opening edge of PH2 (at time = 10), as indicated by the dashed-line arrows in the timing diagram. Arrival after time = 20 would be a timing violation.



Figure 1-15 Time Borrowing in Latch-Based Paths

If the data arrives at L2 before the opening edge of PH2 at time = 10, the data for the next path from L2 to L3 gets launched by the opening edge of PH2 at time = 10, just as a synchronous flip-flop would operate. This timing requirement is labeled Setup 2a.

If the data arrives after the opening edge of PH2, the first path (from L1 to L2) borrows time from the second path (from L2 to L3). In that case, the launch of data for the second path occurs at the data arrival time at L2, at some time between the opening and closing edges of PH2. This timing requirement is labeled Setup 2b. When borrowing occurs, the path originates at the D pin, rather than the G pin, of L2.

For the path from L1 to L2, the tool reports the setup slack as zero if borrowing occurs. The slack is positive if the data arrives before the opening edge at time = 10, or it is negative (a violation) if the data arrives after the closing edge at time = 20.

To perform hold checking, the tool considers the launch and capture edges relative to the setup check. It verifies that data launched at the startpoint does not reach the endpoint too quickly, thereby ensuring that data launched in the previous cycle is latched and not overwritten by the new data. This is depicted in Figure 1-16.

Figure 1-16 Hold Checks in Latch-Based Paths



## **Timing Analysis in the Design Flow**

Timing analysis serves different purposes in different phases of the design flow. In Design Compiler, timing drives the selection of library cells used for synthesis and the allocation of registers between combinational logic in data paths. In IC Compiler, timing drives the placement of cells and the routing of interconnections to minimize delays in the critical paths. In PrimeTime, exhaustive sign-off timing analysis is the main purpose of the tool.

These tools all share the same basic delay calculation methods. The timing results are generally consistent between the tools but not always identical. Because PrimeTime is a sign-off analysis tool, it performs a more comprehensive and exhaustive analysis to verify correct timing, whereas Design Compiler and IC Compiler perform timing analysis with sufficient accuracy to drive synthesis, physical implementation, and optimization.

# **Synopsys Design Constraint (SDC) Commands**

Design Compiler, IC Compiler, and PrimeTime share many common timing analysis features. The tools allow you to use the same commands to specify timing constraints and generate timing reports. These commands are known as the Synopsys Design Constraints, or SDC. These commands have the same syntax and have the same effects across all the

supported tools. That means you can use the same SDC script to constrain a design in Design Compiler, IC Compiler, PrimeTime, and other tools. The SDC commands can specify design rule constraints and power constraints as well as timing constraints.

In each tool, the write\_sdc command writes out a script containing a set of SDC commands that specify the current constraints set on the design. In a different tool, you can use the read\_sdc command to read in the file and apply the same constraints. The read\_sdc command works very much like the source command, but it also checks the script commands for SDC compliance. SDC script files can be used to transfer constraints not only between Synopsys tools, but also certain external tools.

Some Synopsys tools have extended constraint capabilities beyond what is supported by SDC in the form of additional commands or command options. Only the SDC-compatible features are written by the <code>write\_sdc</code> command so that the written commands can be executed in any SDC-compatible tool.

Table 1-1 lists the SDC commands used for specifying timing constraints and timing-related design characteristics. For more information about SDC commands, see the *Using the Synopsys Design Constraints Format Application Note*, which is available on SolvNet in the documentation sets for Design Compiler, IC Compiler, and PrimeTime. To access SolvNet, go to the SolvNet Web page at the following address:

https://solvnet.synopsys.com

Table 1-1 SDC Timing Commands

| Command                | Usage                                                                                                                                                                                                                                   |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_clock           | Specifies the clocks used in the design and their characteristics: name, period, waveform, and design location. The timing analyzer needs this information to determine the required data arrival time at each path endpoint.           |
| group_path             | Groups a set of paths or endpoints for timing analysis and cost function calculations. Paths within a group are analyzed and optimized separately from other groups. By default, there is one path group per clock.                     |
| set_clock_gating_check | Creates one or more clock-gating checks in the design. A clock-gating check is a setup or hold check performed on the control input of a clock-gating cell. This detects occurrences of clipped clocked edges or spurious clock pulses. |
| set_clock_groups       | Specifies groups of clocks that are mutually exclusive or asynchronous with each other. This prevents analysis of a timing path that starts in one clock group and ends in another.                                                     |

Table 1-1 SDC Timing Commands (Continued)

| Command               | Usage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| set_clock_latency     | Specifies explicitly the source latency or network latency of a clock. This command is typically used before layout, when propagated clocking cannot be used. Source latency is the time the clock signal takes to be propagated from its ideal waveform origin point to the clock definition point in the design. Network latency is the time the clock signal takes to be propagated from the clock definition point in the design to the clock pin of the sequential device. The timing analyzer uses this information to determine clock arrival times in the absence of propagated clocking. |
| set_clock_sense       | Specifies the unateness of a clock signal, either positive or negative, that is propagated past a nonunate point in the clock network. A nonunate point is a place where the sense of the clock signal cannot be determined, such as the output of an exclusive OR gate with the clock signal as one input and an unknown side-input value as the other input.                                                                                                                                                                                                                                    |
| set_clock_transition  | Specifies explicitly the rising or falling transition times of a clock. This command is typically used before layout, when propagated clocking cannot be used. The transition time applies to rising or falling transitions at the clock pins of sequential devices clocked by the specified clock. The timing analyzer uses this information to determine clock transition times in the absence of propagated clocking.                                                                                                                                                                          |
| set_clock_uncertainty | Specifies the uncertainty or skew characteristics of a single clock or between two different clocks. For a single clock, simple uncertainty is the maximum difference between successive edges with respect to variation away from the nominal arrival times. For two clocks, interclock uncertainty is the maximum difference or skew between occurrences of clock edges with respect to variation away from the nominal arrival times. The timing analyzer uses this information to determine the worst possible clock arrival times for each timing check.                                     |
| set_data_check        | Creates a custom data-to-data check, also known as a nonsequential constraint, using specified setup and hold time values between the specified data signals. You specify the "from" object or related pin, the "to" object or constrained pin, and the setup or hold value for the check.                                                                                                                                                                                                                                                                                                        |
| set_disable_timing    | Disables timing checks and timing optimization for specified cells, pins, or ports. This command removes the affected objects entirely from timing analysis, unlike the <code>set_false_path</code> command, which removes only the timing constraints, and not delay calculation, from the paths. If all paths through a pin are false, <code>set_disable_timing</code> is more efficient than <code>set_false_path</code> .                                                                                                                                                                     |

Table 1-1 SDC Timing Commands (Continued)

| Command              | Usage                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| set_driving_cell     | Specifies the name of a library cell that drives one or more input ports of the design. This information allows the timing analyzer to accurately determine the delay cause by the driver, load, and wire characteristics of the net.                                                                                                                                                                                                     |  |  |  |
| set_fanout_load      | Specifies the number of external loads in the fanout of one or more output ports of the design. The tool uses this information to enforce the maximum fanout design rule, not for performing timing analysis.                                                                                                                                                                                                                             |  |  |  |
| set_ideal_latency    | Specifies explicitly the ideal clock latency in the transitive fanout of specified ports or pins. Ideal clock latency is the time it takes for a clock signal to propagate from its ideal waveform origin point to the clock pin of the sequential device in an ideal network. The default ideal latency is zero. The timing analysis tool uses the ideal latency to determine clock arrival times in the absence of propagated clocking. |  |  |  |
| set_ideal_network    | Invokes ideal clocking behavior in the transitive fanout of specified ports, pins, or nets, causing explicitly specified latency and transition times (zero by default) to be used throughout the specified network. Ideal clocking is used before layout, when propagated clocking cannot be used.                                                                                                                                       |  |  |  |
| set_ideal_transition | Specifies explicitly the rising or falling transition times of signals in the transitive fanout of specified ports or pins. The default ideal transition time is zero. The timing analysis tool uses the ideal transition time in the absence of propagated clocking.                                                                                                                                                                     |  |  |  |
| set_input_delay      | Specifies the amount of delay from a launch clock edge outside of the design to the arrival of data at an input of the design. This information is necessary to check the timing of signals entering the design inputs.                                                                                                                                                                                                                   |  |  |  |
| set_input_transition | Specifies explicitly the rise or fall transition times on input ports of the design for propagated (not ideal) clocking. The timing analyzer uses this information to determine the delays and transition times of signals in the transitive fanout of the input.                                                                                                                                                                         |  |  |  |
| set_load             | Specifies explicitly the capacitive load on one or more input ports, output ports, or nets. The timing analyzer uses this information to determine the effects of the load on delays and transition times of signals passing through the port or net.                                                                                                                                                                                     |  |  |  |

Table 1-1 SDC Timing Commands (Continued)

| Command                      | Usage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| set_operating_condition<br>s | Specifies the operating conditions under which the design is analyzed and optimized. The library defines the operating conditions, each condition consisting of a set of process, temperature, and voltage values. Each cell in the library has a different set of cell timing characteristics for each operating condition. The command selects one or more of these defined operating conditions by name and invokes either best-case/worst-case analysis or on-chip variation analysis. |  |  |  |
| set_output_delay             | Specifies the amount of delay from the departure of data at an output of the design to the capture clock edge outside the design. This information is necessary to check the timing of signals leaving the design outputs.                                                                                                                                                                                                                                                                 |  |  |  |
| set_port_fanout_number       | Specifies the number of external loads in the fanout of one or more output ports of the design. This allows the timing analyzer to estimate the total wire load of the external devices connected to the output.                                                                                                                                                                                                                                                                           |  |  |  |
| set_propagated_clock         | Causes network latency to be determined by propagating delays through the clock network for specified clocks or for the transitive fanout of specified ports or pins. Propagated clocking can be used after layout, when detailed net RC information is available.                                                                                                                                                                                                                         |  |  |  |
| set_resistance               | Specifies explicitly the resistance of one or more nets. The timing analyzer uses this information to determine the effects of the resistance on delays and transition times of signals passing through the net.                                                                                                                                                                                                                                                                           |  |  |  |
| set_timing_derate            | Applies derating or adjustment factors to specified delays of timing checks. Derating can be used to model the worst-case effects of process, voltage, and temperature variation.                                                                                                                                                                                                                                                                                                          |  |  |  |
| set_wire_load_model          | Specifies the types of wire load models used for estimating wire resistance and capacitance before routing has been performed. Used in Design Compiler and PrimeTime; not used in Design Compiler with topographical technology or IC Compiler.                                                                                                                                                                                                                                            |  |  |  |

To remove all constraints from the design, use the remove\_sdc command.

# **Library Timing Data**

To perform timing analysis, the tool needs information about the timing characteristics of the logic cells used in the design, such as the input-to-output delays of combinational logic blocks; clock-to-output delays, setup times, and hold times of sequential blocks; and transition times of cell output signals. The cell timing characteristics are contained in the library description of each cell. Timing analysis tools can read the library data in the following forms:

- Liberty (.lib) format using the read lib command
- Synopsys database (.db) format using the read\_db or read\_file command
- LM (logic model) view of the Milkyway database using the open\_mw\_lib command

The cell timing characteristics are typically determined by a characterization tool such as Liberty NCX in combination with a circuit simulator such as HSPICE. Liberty NCX writes out the cell timing data in Liberty (.lib) format, a human-readable text format. Some timing analysis tools can read .lib files directly with the read\_lib command.

Libraries in Liberty (.lib) format are typically compiled into Synopsys database (.db) format by Library Compiler. The .db file is a binary format that is more compact and faster to read than the .lib format. A timing analysis tool can read in a .db library directly with the read\_db command or implicitly via the link\_library variable setting.

One or more .lib and .db libraries can be merged into the LM (logic model) view of the Milkyway database. The Milkyway database provides a common place to keep library data that can be easily accessed by multiple tools with the <code>open\_mw\_lib</code> command.

Each cell timing parameter, such as input-to-output delay or output transition time, is a function of the input slew and output load. Accordingly, the delay information is organized in a table of values corresponding to different combinations of input slew and output load. You can view the timing parameter tables in the .lib library file, if available. You can also view the timing data in the analysis tool by using the report\_lib -timing command. For example,

. .

The table lists the delay values from the input A2 to the output ZN for a rising signal, for each possible combination of an input transition time and an output capacitive load taken from the index tables. The delay calculator uses interpolation or extrapolation to get delay values for input transition times and capacitive loads between or outside of the index tables. Similar tables specify the output transition times as a function of input transition and output load. The output transition time calculated for a cell becomes the input transition time for the next cell in the timing path.

For a detailed description of the delay calculation for a particular cell instance or net in the design, you can use the report\_delay\_calculation command. For example,

```
prompt> report_delay_calculation -from I_RISC_CORE/I_ALU/U27/A2 \
          -to I_RISC_CORE/I_ALU/U27/ZN
Rise Delay
   cell delay = 0.0583731
    Table is indexed by
      (X) input_pin_transition = 0.103374
      (Y) output_net_total_cap = 0.00451049
    Relevant portion of lookup table:
                  (X) 0.0150
                                  (X) 0.2500
                                  (Z) 0.0680
  (Y) 0.0000
                  (Z) 0.0270
  (Y) 0.0070
                  (Z) 0.0480
                                  (Z) 0.0990
    Z = A + B*X + C*Y + D*X*Y
    A = 0.0244 B = 0.1745
    C = 2.9088
                         D = 6.0790
  Z = 0.0583731
  scaling result for operating conditions
 multiplying by 1 gives 0.0583731
```

Cell delays vary with operating conditions, so the libraries may have different delay values for different operating condition corners. A corner is a particular combination of voltage, temperature, and process values. Some libraries are designed for scaling so that the

analysis tool can obtain accurate delay values at intermediate operating conditions by using interpolation between the defined operating conditions and their corresponding delay values.

### **Design Compiler**

Design Compiler is a synthesis tool that converts a design description at the Register Transfer Level (RTL) to a gate-level netlist. The synthesis process performed by Design Compiler typically consists of the following major steps:

- Read in the RTL description in Verilog or VHDL format.
- Read in the timing, area, and power constraints in Synopsys Design Constraints (SDC) format.
- Generate the design logic using generic Boolean gates, optimize the logic, and map the design into a netlist using the technology-specific gates of the target library.
- Write out the compiled gate-level netlist in .ddc format.

Although the area and power constraints are important, only the timing constraints must be absolutely satisfied for the circuit to operate. Timing drives the logic implementation and selection of gates from the library to ensure that timing path delays do not exceed the applicable clock periods. For example, where a setup delay is found to be too long, Design Compiler might use larger devices with more drive strength to reduce net delays, at the expense of more area.

After you apply the timing constraints to the design, you should check for timing constraint and setup problems with the <code>check\_timing</code> command. After synthesis is completed, you can report the worst-case paths and analyze them in detail with the <code>report\_constraint</code> and <code>report\_timing</code> commands.

# **Ideal Clocking**

At the logic synthesis stage before layout, performing clock tree synthesis is not practical because the wire lengths are unknown and the clock skew is highly sensitive to parasitic interconnect differences. By default, Design Compiler uses ideal clocking, which means zero latency, zero uncertainty, and zero transition time for all clock signals. Latency is the delay from the clock source to the clock register pins, which is zero for ideal clocking, based on the assumption of zero resistance and capacitance of the clock network. All nets and cells in the clock network are automatically marked as <code>dont\_touch</code>. Ideal networks are not optimized or buffered during synthesis.

Ideal clocking is highly optimistic. To get more accurate timing results, you can specify nonzero latency, uncertainty, and transition times for clock signals to represent the approximate timing values expected for the completed clock network. For example,

```
dc_shell> set_clock_latency 1.2 -rise [get_clocks CLK1]
dc_shell> set_clock_latency 0.9 -fall [get_clocks CLK1]
dc_shell> set_clock_uncertainty -setup 0.65 [get_clocks CLK1]
dc_shell> set_clock_uncertainty -hold 0.45 [get_clocks CLK1]
dc_shell> set_clock_transition 0.34 -rise [get_clocks CLK1]
dc_shell> set_clock_transition 0.30 -fall [get_clocks CLK1]
```

With settings such as these, the clock network is still treated as ideal, but with the specified latency, uncertainty, and skew values instead of zero throughout the clock network.

High-fanout nets other than clocks, such as reset or enable signals, might also require buffer trees that are synthesized at the layout stage rather than in Design Compiler. For these nets, you can specify ideal network behavior and nonzero latency and transition times for synthesis, in anticipation of high-fanout network synthesis in the layout tool. For example,

```
dc_shell> set_ideal_network [get_ports Reset]
dc_shell> set_ideal_latency 1.40 [get_ports Reset]
dc_shell> set_ideal_transition 0.30 [get_ports Reset]
```

### Wire Load Models and Topographical Technology

To perform accurate timing analysis, both cell delays and net delays must be known. However, at the prelayout logic synthesis stage, the exact net delays cannot be determined because the wire lengths are unknown. There are two methods you can use to estimate the RC wire characteristics in Design Compiler: wire load models and topographical technology.

A wire load model obtains one parasitic resistance value and one capacitance value for each net, based on the net's fanout. A net having a larger fanout is assumed to have more wires and therefore more resistance and capacitance. Wire load models are supplied in the technology library. The models are based on data extracted from similar designs for similar size, fabricated with the same process technology.

A library typically has several wire load models to be used for different design sizes. As the size of a design increases, standard cells can be placed physically farther apart within that design, which means that wire lengths are typically longer. Some library vendors may use names for their models to represent different design sizes, such as "300kGates," 600kGates," and so on. It is important to select the appropriate wire load model for the design according to size. For example,

```
dc_shell> set_wire_load_model -name 1.6MGates
```

The specified model applies to all nets at the current design level and below. When the design is hierarchical and the blocks are grouped into physical areas of the chip, then smaller individual wire load models can better represent the actual RC values within each lower-level subdesign. For example,

```
dc_shell> set_wire_load_model -name 1.6MGates
dc_shell> set_wire_load_mode enclosed
dc_shell> set_wire_load_model -name 800KGates [get_designs SUB1]
dc_shell> set_wire_load_model -name 200KGates [get_designs B1]
dc_shell> set_wire_load_model -name 100KGates [get_designs B2]
```

Setting the wire load mode to "enclosed" means that the wire capacitance of each net is calculated using the wire load model set on the smallest subdesign that completely encloses that net.

Some libraries support automatic wire load selection based on the area of the design. Usage of this feature can be controlled with the auto\_wire\_load\_selection variable.

Wire load models are based on statistical averages and are not specific to the particular design. In ultra-deep submicron designs, wire load models may not provide enough accuracy because of the increased impact of wire parasitics on path delays. For these designs, Design Compiler with topographical technology is recommended.

Design Compiler with topographical technology accurately predicts timing during synthesis without using wire load models. Instead, it uses physical information from the Milkyway database to accurately predict actual wire lengths and obtain more accurate predictions of actual wire resistance and capacitance values. It uses the design floorplan if available, or it creates its own floorplan if needed, to get the placement information it needs for predicting wire lengths. The topographical mode requires DC Ultra and DesignWare licenses.

To run Design Compiler in topographical mode, use the -topographical option when you invoke dc shell:

```
% dc_shell -topographical
...
Initializing...
Starting shell in Topographical mode...
...
dc_shell-topo>
```

The shell prompt is <code>dc\_shell-topo></code> in topographical mode. No wire load models are needed; if any are present, they are ignored. When you run the <code>compile\_ultra</code> command, it automatically invokes the topographical features. The command performs placement in the background to estimate wire lengths accurately. Cell placement based is on an existing floorplan provided in DEF format or a floorplan specified manually with commands such as <code>set\_placement\_area</code>, <code>set\_port\_location</code>, <code>set\_cell\_location</code>, and <code>create\_placement\_bounds</code>.

The physical Milkyway reference libraries contain the physical layout descriptions of the cells in the synthesized netlist, including standard cells, macro cells, and pad cells, which Design Compiler uses for topographical placement during compile operations. The technology file defines the process metal layers, physical design rules, units of resistance, capacitance, and so on. The TLUPlus files define models for calculating ultra-deep-submicron RC parasitic values from extracted wire data.

By using this physical information, Design Compiler obtains a placement model that accurately predicts wire lengths and therefore wire RC and delay characteristics. The result is a higher-quality synthesis and fewer design iterations between logic synthesis and physical implementation.

### **Design Partitioning**

A large design is typically divided into a hierarchy of blocks, often organized by function, to break down the design and implementation task into manageable units. To get the best possible results, it is important to partition the design in a manner that allows Design Compiler to optimize the timing and area within the boundaries of each block.

For example, consider the partitioning of logic shown in Figure 1-17. The combinational logic between Register A and Register B has been divided between Block A and Block B. Some "glue logic," an inverter, holds the logic together at the top level. Design Compiler must preserve the Block A and Block B pin definitions, so it cannot perform logic optimization across the hierarchical boundary between them. Furthermore, there is no opportunity to optimize away the inverter at the top level.

Figure 1-17 Poorly Partitioned Blocks



The logic partitioning shown in Figure 1-18 is much better. The combinational logic between Register A and Register B has been moved entirely into Block B, including the top-level "glue logic." This partitioning allows Design Compiler to optimize all of the logic together inside block B, possibly resulting in less time delay, smaller area, or both for that portion of the combinational logic. The partition was made at the output of Register A, not at the input of Register B, to give Design Compiler an opportunity to further optimize the logic by using a more complex flip-flop cell. For example, a multiplexing function in the logic could be implemented by using an enable-type flip-flop.

Figure 1-18 Well-Partitioned Blocks



For better results, avoid dividing combinational logic between different blocks. Instead, keep as much combinational logic together and keep it with the downstream registers, such as Register B in the foregoing example. Where necessary, make a partition at the output of a register, such as the output of Register A in the foregoing example. This simplifies the setting of input and output timing constraints for lower-level block synthesis and provides Design Compiler with nearly a whole clock cycle in which to optimize the register-to-register logic.

Performing good partitioning in the original RTL is the best strategy. However, if the RTL partitioning is not favorable, you can improve the partitioning in Design Compiler by ungrouping and regrouping the logic into a more favorable configuration prior to the compile operation. The <code>compile\_ultra</code> command, by default, performs automatic repartitioning. You can also manually repartition the design with the <code>ungroup</code> and <code>group</code> commands.

### **Path Groups**

The timing paths of the design are organized into groups called *path groups* (not to be confused with *logic grouping* described in the foregoing section). By default, there is one path group for each clock in the design. All timing paths clocked by a given clock at the path endpoint belong to that clock's path group. A design that has only a single clock has only one clocked path group, so all clocked paths in the design belong to that group.

All timing paths within a path group are optimized for timing together, starting with the critical path, which is the path having the worst slack within the group. After the critical path is fixed, the next-worst path becomes the new critical path and the target for fixing. The tool continues fixing paths until all paths in the group have zero slack or until a better optimization solution for the current critical path cannot be found. In the latter case, the subcritical paths are not fixed, but are left with timing violations. The subcritical paths are the paths with better slack than the critical path, but that are still in violation.

Paths within a group are optimized and reported separately from other groups. For example, in a design with two clocks, CLK1 and CLK2, there are two path groups. Design Compiler optimizes each path group in turn, starting with the critical path in each group, even if the worst slacks are different between the two groups.

You can optionally divide the paths into groups to control the focus of optimization effort on targeted paths. For example, if you are not sure about the input delay requirements, you can put the input-to-register paths into a separate group. In that case, the input-to-register paths are optimized separately from the other paths and the worst input-to-register violation does not prevent optimization of register-to-register paths clocked by the same clock.

The command for grouping paths is group\_path. For example,

```
dc_shell> create_clock -name CLK -period 1.67 [get_ports CLK
dc_shell> group_path -name INREG -from [all_inputs]
dc_shell> group_path -name REGOUT -to [all_outputs]
dc_shell> group_path -name INOUT -from [all_inputs] -to [all_outputs]
```

By default, all paths clocked by CLK at the path endpoint belong to the CLK path group. In this example, the three <code>group\_path</code> commands place the input-to-register, register-to-output, and input-to-output paths into separate path groups called INREG, REGOUT, and INOUT, respectively. The register-to-register paths remain in the default CLK group as demonstrated in Figure 1-19.

Figure 1-19 Timing Path Groups



With this path grouping, any problems encountered in optimizing input-related or output-related timing paths will not affect the optimization of register-to-register paths. Furthermore, the report\_timing command reports the worst path in each path group separately, so you can find out about the worst register-to-register paths separately from the input-related and output-related paths.

You can optionally assign a weight, also known as cost function, to each path group so that Design Compiler applies more effort to optimizing the targeted group. The default weighting value for each path group is 1. The higher the weighting, the higher the effort applied to the group. For example, the following commands assign the input-related and output-related paths as in the previous example, but also specify an effort level of 5 for the register-to-register paths and 2 to the input-to-register paths. The effort level remains at 1 for the other types of paths.

```
dc_shell> create_clock -name CLK -period 1.67 [get_ports CLK
dc_shell> group_path -name INREG -from [all_inputs] -weight 2
dc_shell> group_path -name REGOUT -to [all_outputs]
dc_shell> group_path -name INOUT -from [all_inputs] -to [all_outputs]
dc_shell> group_path -name CLK -weight 5
```

Higher weighting for a group means that Design Compiler will attempt to reduce the size of a timing violation for a path in that group at the expense of slack in a path belonging to a lower-weighted group.

To get information about the current set of path groups, use the report\_path\_group command. To remove a path group, use the remove\_path\_group command. Paths belonging to a removed group are implicitly assigned to the default path group.

### **Register Retiming Optimization**

Another way to meet timing constraints is to reposition registers within the combinational logic. For example, in Figure 1-20, the timing path on the left has a setup timing violation due to a long combinational logic path, with a total slack of -1.0 for the path. Meanwhile, the short timing path downstream has a positive slack of +1.5.

Figure 1-20 Setup Timing Violation



Design Compiler can fix this violation by changing the implementation as shown in Figure 1-21. It takes away the register at the output of the NAND gate and replaces it with two new registers at the inputs of the same NAND gate. This produces a logically equivalent circuit that passes setup timing for both paths. The change effectively takes away the delay of the NAND gate from the violating path and gives that delay to the downstream path. The cost of this timing violation correction is the area of the additional register in the circuit.

Figure 1-21 Violation Fixed by Register Retiming



Conversely, a circuit like the one shown in Figure 1-21, but with some available timing slack in the first timing path, can reduce the total area by taking away the two registers at the inputs of the NAND gate and replacing them with a single register at the output of the NAND gate.

Optimization performed by splitting or merging registers and moving those registers through combinational logic, whether for better timing or better area, is called *register repositioning* or *register retiming*. This type of optimization is performed with the command compile\_ultra -retime, balance\_registers, optimize\_registers, or pipeline\_design.

### **IC Compiler**

IC Compiler is a comprehensive chip-level physical implementation tool that supports design planning, placement, clock tree synthesis, routing, test, and design-for-manufacturing (DFM) capabilities. Starting from a gate-level netlist, IC Compiler generates a placed and routed design with clock trees, fully optimized and prepared for manufacturing. An IC Compiler session typically consists of the following major steps:

- Setup
- Design planning
- Placement (place\_opt command)
- Clock tree synthesis (clock opt command)
- Routing (route\_opt command)
- Analysis
- Chip finishing

Timing analysis plays an important role in design planning, placement, clock tree synthesis, routing, and post-route analysis. The same timing constraints applied to logic synthesis in Design Compiler should be applied to physical implementation in IC Compiler, including operating conditions, clocks, input drivers, output loads, input/output delays, and timing exceptions. You can also specify physical constraints such as area, utilization, congestion, and layer usage for routing. After you apply the timing constraints, you should check for timing constraint and setup problems with the <code>check\_timing</code> command.

### **Design Planning**

In the design planning context, floorplanning is the process of sizing and placing hierarchical cells and functional blocks in a manner that makes later physical design steps more effective. Floorplanning in hierarchical flows provides a basis for estimating the timing of the top level. A timing budget allocates the clock cycle time to each block according to the top-level timing estimation.

An effective floorplan helps ensure timing closure in many ways, such as placing blocks to make critical paths short, preventing routing congestion that would lead to longer paths, and eliminating the need for over-the-top routing for noise-sensitive blocks. The challenge is to create a floorplan with good area efficiency while leaving sufficient area for routing.

You can check the timing of the entire design at various stages of the design planning flow by using the <code>check\_timing</code> and <code>report\_timing</code> commands. You can also use the <code>check\_fp\_timing\_environment</code> command to check the timing budgets assigned to each block.

After the design passes the early timing feasibility checks, you can perform timing budgeting on plan groups by using the allocate\_fp\_budgets command. Timing budgeting generates the SDC constraints and attributes for the individual plan groups. These constraints and attributes are then transferred to the individual soft macro blocks when the hierarchy is committed using the commit\_fp\_plan\_groups command.

Timing budgeting can also consider crosstalk effects across soft macro boundaries when generating SDC constraints. Before running timing budgeting, set the <code>enable\_hier\_si</code> variable to true to enable signal integrity budgeting and take into account the crosstalk timing effects across soft macro boundaries.

Clock planning is an optional step in the design planning flow. You can use clock planning to estimate the clock tree insertion delay and skew in a hierarchical design. Clock planning also helps determine the optimal clock pin locations on blocks. Clock planning inserts anchor cells to isolate the clock trees inside the plan group from the top-level clock tree. It then runs fast clock tree synthesis for each plan group to estimate the clock skew and insertion delay. You set up and perform clock planning with the

set\_fp\_clock\_plan\_options and compile\_fp\_clock\_plan commands.

### **Placement**

Placement is the process of finding a suitable physical location for each cell in the design. Placement is performed in two stages: coarse placement and legalization.

During coarse placement, IC Compiler determines an approximate location for each cell according to the timing and congestion constraints. The placed cells do not fall on the placement grid and may overlap each other. Large cells, such as RAM and IP blocks, act as

placement blockages for smaller, leaf-level cells. Coarse placement is fast and is sufficiently accurate for initial timing and congestion analysis.

During legalization, IC Compiler moves the cells to precisely legal locations on the placement grid and eliminates any overlap between cells. The small changes to cell locations cause the lengths of the wire connections to change, possibly causing new timing violations. Such violations can often be fixed by incremental optimization, for example, by resizing the driving cells.

The place\_opt command is recommended for performing placement in most situations. This command performs coarse placement, high-fanout net synthesis, physical optimization, and legalization, all in a single operation. In certain applications, you might want to perform placement tasks individually using commands such as <code>create\_placement</code> and <code>physopt</code>, for a greater degree of control or to closely monitor the results as they are generated.

In the placement process, IC Compiler considers possible trade-offs between timing and congestion. Timing considerations bring cells closer together to minimize wire lengths and therefore wire delays. On the other hand, the occurrence of congestion draws cells farther apart to provide room for the connections. Congestion cannot be ignored entirely in favor of timing because rerouting wires around congested areas will cause an increase in wire lengths and wire delays, thus defeating the value of close placement.

In the place\_opt command, the -congestion option causes the tool to apply more effort to congestion removal, resulting in better routability. However, this option should be used only if congestion is expected to be a problem because it requires more runtime and causes area utilization to be less uniform across the available placement area. If congestion is found to be a problem after placement and optimization, it can be improved incrementally with the refine\_placement command. Timing, area, and congestion optimization can also be done incrementally with the psynopt command.

The <code>-area\_recovery</code> option of the <code>place\_opt</code> command allows IC Compiler to recover chip area where there is extra timing slack available. For example, it can resize cells smaller in timing paths where there is a positive timing slack.

Placement is typically done before clock tree synthesis, so the clock network is ideal and does not have a clock buffer tree available for accurate clock network timing analysis. To get more accurate timing results, you should use the same commands as those used in Design Compiler to specify nonzero latency, uncertainty, and transition times for the clock network. For example,

```
icc_shell> set_clock_latency 1.2 -rise [get_clocks CLK1]
icc_shell> set_clock_latency 0.9 -fall [get_clocks CLK1]
icc_shell> set_clock_uncertainty -setup 0.65 [get_clocks CLK1]
icc_shell> set_clock_uncertainty -hold 0.45 [get_clocks CLK1]
icc_shell> set_clock_transition 0.34 -rise [get_clocks CLK1]
icc_shell> set_clock_transition 0.30 -fall [get_clocks CLK1]
```

As in Design Compiler, the clock network is still treated as ideal, but with the specified latency, uncertainty, and skew values instead of zero throughout the clock network.

By default, the place\_opt command does not perform clock tree synthesis. However, if the clock tree is relatively simple and if it uses the same routing rules as signal routes, you can perform clock tree synthesis simultaneously with placement. In that case, you can use propagated delays instead of ideal clocking during placement and optimization. To do so, use the -cts option in the place\_opt command.

The place\_opt command does not perform clock tree synthesis by default. However, it does perform synthesis of high-fanout nets such as resent and scan-enabled signals. When skew is an issue with a high-fanout net, you should compile it separately with the compile\_clock\_tree -high\_fanout\_net command.

### **Clock Tree Synthesis**

By default, clock networks are considered ideal during logic synthesis and physical placement. An ideal clock network consists of a single driver connected to all the sequential devices in the design clocked by that clock, without any buffers. An ideal network can have zero latency, uncertainty, or transition times; or you can specify nonzero latency, uncertainty, and transition times that are uniform throughout the clock network.

Clock tree synthesis is the replacement of an ideal clock network with a hierarchy of buffers with the goal of minimizing latency, skew, and transition times. This is typically done after placement and high-fanout net synthesis and before routing. The <code>clock\_opt</code> command performs clock tree synthesis, including logic synthesis of the buffer tree, routing of the clock nets, RC extraction from synthesized clock network, and clock tree optimization. You can optionally perform hold-time fixing, interclock delay balancing, area recovery, and other clock tree optimization functions.

You can perform the clock tree synthesis in steps for greater control and to closely monitor and analyze the results as they are generated. For example, the following commands perform clock tree synthesis without routing, followed by clock tree optimization without routing, and finally routing of the optimized clock nets:

```
icc_shell> clock_opt -only_cts -no_clock_route
  (timing analysis of compiled clock tree here)
   ...
icc_shell> clock_opt -only_psyn -no_clock_route
  (timing analysis of optimized clock tree here)
   ...
icc_shell> route_group -all_clock_nets
  (timing analysis of fully routed clock tree here)
   ...
```

You can also choose to perform the clock tree synthesis steps separately using commands such as <code>compile\_clock\_tree</code> and <code>optimize\_clock\_tree</code>. To use propagated rather than ideal latency and transition time, you can use the commands <code>set\_propagated\_clock</code> and <code>remove\_ideal\_network</code>. For details, see the applicable man pages.

Several commands let you specify the parameters for clock tree synthesis before you use the <code>clock\_opt</code> command. Use the <code>set\_clock\_tree\_references</code> command to specify which buffer and inverter cells to use for implementing the clock tree. Use the <code>set\_clock\_tree\_options</code> commands to specify the layers used for routing clock nets, the target delay and skew, the maximum number of buffer levels, the maximum capacitance, transition time, and fanout rules for the buffers used in the tree. Use the <code>set\_clock\_tree\_exceptions</code> command to apply exceptions to normal clock tree synthesis behavior to specified objects in the design, such as stop pins, nonstop pins, exclude pins, "don't-buffer" nets, "don't-size" cells, and size-only cells.

You can apply nondefault routing rules to the routing of clock nets such as shielding, extra width, or extra spacing to reduce the effects of parasitic resistance, electromigration, and crosstalk. You specify nondefault routing rules with the <code>define\_routing\_rule</code> command and then invoke those rules with the <code>-routing\_rule</code> option of the set clock tree options command.

To check and fix hold violations, use the  $-fix\_hold\_all\_clocks$  or  $-only\_hold\_time$  option with the  $clock\_opt$  command. The  $-fix\_hold\_all\_clocks$  option fixes hold violations for all clocks. The  $-only\_hold\_time$  option fixes only hold time violations and does nothing else.

# **Routing**

Routing is the process of defining physical connections to all clock and signal pins through metal paths. The routed paths must meet setup and hold timing requirements, maximum capacitance and transition time design rules, and clock skew requirements. Furthermore, the metal traces must meet physical design rules such as minimum width and minimum spacing.

Cell placement and clock tree synthesis must be completed before routing starts. The power and ground nets must be routed. The estimated congestion must be acceptable and the estimated timing must show the worst slack to be at least zero or near zero. There can be no maximum capacitance or maximum transition violations.

Routing consists of three main stages: global routing, track assignment, and detail routing. In global routing, the router divides the chip area into global routing cells and assigns routes to the available tracks in each routing cell. The router avoids congested cells by detouring routes around the congested areas. It considers the additional time delay of the longer routes. In track assignment, the router assigns each net to a specific track within each global

routing cell and attempts to make long, straight traces with as few vias as possible. In detail routing, the router fixes physical DRC violations such as minimum width and minimum spacing. By default, the clock nets are routed first, then the signal nets.

You can use either the classic router or Zroute to perform routing. Zroute is recommended if you have an available license because of its higher quality of results. To invoke Zroute IC Compiler, use set\_route\_mode\_options -zroute true.

The route\_opt command performs global routing, track assignment, detail routing, and route optimization. The command options let you specify the effort level and the types of optimization performed such as wire sizing, cell sizing, area recovery, leakage power, and fixing of hold violations. A higher effort level produces more highly optimized results at the cost of more runtime. You can choose to limit the routing stages performed (global, track, or detail) or perform incremental optimization of a previously routed design.

By default, the router does not check or fix crosstalk conditions. To invoke crosstalk checking and repair during routing, use the following commands:

```
icc_shell> set_si_options -delta_delay true or -static_noise true ...
icc_shell> route_opt -xtalk_reduction or -only_xtalk_reduction ...
```

Crosstalk issues can also be reduced by applying nondefault routing rules for clocks and other sensitive signals, enforcing maximum transition rules, reducing congestion, and limiting the extent of area recovery performed during optimization.

# **Timing Analysis After Routing**

After routing, detailed nets are available for accurate RC extraction, thereby producing more accurate delay calculation results. The report\_constraint command reports timing violations, and the report\_timing command generates detailed reports on the critical paths.

The default delay calculation is the fast Elmore delay model. However, after routing is complete, you can choose to invoke the more accurate Arnoldi delay model by using set\_delay\_calculation -arnoldi.

For a complete and final design, you should use a sign-off extraction tool such as Star-RCXT and a sign-off timing tool such as PrimeTime. The goal of a sign-off tool is to verify with the greatest possible accuracy that the design will work properly with respect to timing. The sign-off tools perform extraction and timing analysis more accurately than the tools that perform synthesis, physical implementation, and optimization.

Star-RCXT is a full-chip parasitic RC extraction tool that considers all capacitive interactions between conductors and accurately models physical characteristics of wires such as dishing, erosion, and physical proximity of nearby features. Star-RCXT extracts billions of capacitors for a typical design and uses an advanced parasitic reduction method to generate the smallest possible netlist that can achieve accurate timing analysis results.

PrimeTime is a full-chip static timing analyzer that uses the same libraries, gate-level netlist, parasitic RC data, and SDC timing constraints as Design Compiler and IC Compiler. PrimeTime performs a comprehensive analysis with maximum speed and accuracy, producing results that are very consistent with SPICE simulation. The optional add-on features known as PrimeTime SI, PrimeTime VX, and PrimeTime PX perform crosstalk delay and noise analysis, variation-aware analysis, and power analysis, respectively.

The run\_signoff command performs sign-off analysis by invoking the sign-off tools Star-RCXT and PrimeTime in the background. Star-RCXT performs sign-off quality parasitic extraction, and PrimeTime performs sign-off quality timing and crosstalk analysis. You can use the sign-off costing from these tools to perform optimization on the design with the signoff\_opt command. The commands for setting up the sign-off tools are set\_starrcxt\_options and set\_primetime\_options.

# **Synthesis Design Rules**

Synthesis design rules are technology-specific constraints that must be met for a design to function correctly. These rules include minimum and maximum capacitance, maximum transition time, and maximum fanout. Design rule constraints are different from timing constraints such as clock period, input delay, and output delay, and also different from optimization constraints such as area and power.

Synthesis and optimization tools attempt to meet all constraints placed on a design, but by default, they give highest priority to design rule constraints. Meeting the timing constraints is also a requirement for correct operation, but design rule constraints are given higher priority. Area and power optimization constraints reflect goals that are desirable, but not absolutely required for correct operation.

Design rules are typically specified in the technology, but they can also be specified by commands in the synthesis, optimization, or analysis tools. Table 1-2 lists the SDC commands used for specifying synthesis design rules. These commands do not directly

affect timing analysis or timing optimization because design rules are enforced separately from optimization goals. However, the enforcement of design rules provides a basis for ultimately achieving the timing goals of the design.

Table 1-2 SDC Design Rule Commands

| Command             | Usage                                                                                                                                                                                                                                                                  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| set_fanout_load     | Specifies the number of external loads in the fanout of one or more output ports of the design. The synthesis or optimization tool uses this information to enforce the maximum fanout design rule.                                                                    |
| set_max_capacitance | Specifies the maximum allowed capacitance for specified input ports or all input ports of a design. The synthesis or optimization tool ensures that the loading of the input port is small enough to keep the total capacitance no more the specified maximum value.   |
| set_max_fanout      | Specifies the maximum allowed fanout for specified input ports or all input ports of a design. The synthesis or optimization tool ensures that the number of loads connected to the input port is small enough to keep the fanout no more the specified maximum value. |
| set_max_transition  | Specifies the maximum allowed signal transition time for a net, applied to nets belonging to specified clock groups, specified ports, or the whole design. The synthesis or optimization tool ensures that the transition time is no more the specified maximum value. |
| set_min_capacitance | Specifies the minimum allowed capacitance of specified input ports or all input ports of a design. The synthesis or optimization tool ensures that the loading of the input port is large enough to keep the total capacitance at least the specified minimum value.   |

To remove all SDC constraints from the design, including both timing constraints and design rule constraints, use the remove sdc command.

In some cases, there can be a conflict between design rule constraints and timing constraints. For example, the maximum fanout design rule might require the insertion of buffers in a high-fanout net, thus increasing the path delay and possibly causing timing violations. By default, design rules have a higher "cost priority" than timing constraints. The tool first attempts to meet all design rules without causing timing violations, but if this is not possible, it satisfies the design rules and allows timing violations to occur.

You can optionally change the order of priority with the set\_cost\_priority command. For example, to set the cost priority of timing delay at the top:

prompt> set\_cost\_priority -delay

By increasing the cost priority of delay, the tool still attempts to fix design rule violations such as maximum fanout, but not at the expense of delay. Any remaining design rule violations can be addressed in the back-end or physical design. The command also lets you set the relative priority of design rules, as in the following example:

prompt> set\_cost\_priority {max\_fanout max\_capacitance max\_delay}

This command sets the cost priority highest for maximum fanout, followed by maximum capacitance, maximum delay, and then by the unlisted design rules. To find out if the constraints are met, use the report\_constraint command.

# 2

# Clocks

An essential part of timing analysis is to accurately specify clocks and clock effects, such as latency and uncertainty. You can specify, report, and analyze clocks as described in the following sections:

- Creating Clocks
- Clock Network Effects
- Multiple Clocks
- Clock Sense
- Pulse Clocks
- Generated Clocks
- Estimated I/O Latency
- Propagated Clocks

# **Creating Clocks**

You must specify all of the clocks in the design by using the <code>create\_clock</code> command. This is the command syntax:

```
create_clock
  [source_objects]
  [-period period_value]
  [-waveform edge_list]
  [-name clock_name]
  [-add]
```

The *source\_object* is the place in the design where the clock exists, which is usually an input port but can also be a pin inside the design. The analysis tool traces the clock network so that the clock reaches all registers in the transitive fanout of the source object. If you do not specify a source object, you define a *virtual clock*, which is a clock used as a reference for setting input delays and output delays but does not physically exist in the design.

Each clock should have its period defined with the -period option. This is the period of time over which the same waveform repeats end-to-end.

By default, a clock has a 50 percent duty cycle with a rising edge at time zero and a falling edge at one-half the period. If the clock does not have this simple form, you specify the waveform with the <code>-waveform</code> option and provide a list of rising and falling edge times within the clock period. For example, the following commands create a clock having the default waveform and another clock with a rising edge at 1.0 and a falling edge at 2.0. The resulting clock waveforms are shown in Figure 2-1.

```
prompt> create_clock -period 5.0 [get_ports CK1]
prompt> create_clock -period 5.0 -waveform {1.0 2.0} [get_ports CK2]
```

Figure 2-1 Clock Waveforms



You can optionally specify a name for the clock with the <code>-name</code> option. If you do not specify a name explicitly, the clock gets its name from the source object. The <code>-add</code> option lets you add multiple clocks to the same source object in the design.

By default, a clock created with the <code>create\_clock</code> command is ideal. It has zero delay at the source object, zero propagation delay, zero transition time, and zero uncertainty. For an accurate timing analysis, you need to specify clock characteristics such as latency, skew, uncertainty, and transition time. To specify the source latency or network latency of the clock, use the <code>set\_clock\_latency</code> command. To add skew or uncertainty to an ideal clock, use the <code>set\_clock\_uncertainty</code> command. To specify the transition time, use the <code>set\_clock\_transition</code> command. Alternatively, to enable calculation of propagated delay through the network using wire parasitic data, use the <code>set\_propagated\_clock</code> command.

To get a report on clocks that have been defined for the design, use the report\_clock command. To create a collection of clocks, use the get\_clocks or all\_clocks command. For example, to generate a report on the clocks having names starting with PHI1 and a period less than or equal to 5.0, use the following command:

```
prompt> report_clock [get_clocks -filter "period <= 5.0" PHI1*]</pre>
```

The <code>get\_clocks</code> and <code>get\_ports</code> commands can be used to distinguish between a clock object and port object that share the same name.

To get a report on the transitive fanout of a clock source, use the report\_transitive\_fanout command. The report lists the successive driver and load pins fanning out from the specified source object. Similarly, to get a report on the transitive fanin of a clock sink, use the report\_transitive\_fanin command. The report shows the successive driver and load pins in the path feeding into the sink object.

To remove a defined clock, use the remove\_clock command. The reset\_design command also removes all clocks as well as other design information.

### **Clock Network Effects**

For accurate timing analysis, you must describe the clock network. The main characteristics of a clock network are latency, uncertainty, and transition time. Figure 2-2 shows the timing effects of clock networks.

Figure 2-2 Clock Network Effects



Latency is the amount of time it takes for the clock signal to be propagated from the original clock source to the sequential elements in the design. It consists of two components, source latency and network latency. Source latency is the delay from the clock source to the clock definition pin in the design. Network latency is the delay from the clock definition point to the register clock pin.

Uncertainty is the maximum difference between the arrival of clock signals at registers in one clock domain or between domains. This is also called skew. The larger the skew, the more difficult it is to meet the timing constraints.

Transition time is the amount of time it takes for a signal to change from logic low to logic high (rise time), or from logic high to logic low (fall time). The transition time of a signal at an input of a cell affects the delay to the output of the cell and the transition time of the output signal.

### **Clock Latency**

Latency is the amount of time it takes for the clock signal to be propagated from the original clock source to the sequential elements in the design, consisting of two components, source latency and network latency. Source latency, also known as insertion delay, is the time it takes for a clock to be propagated from its ideal waveform origin point to the clock definition point in the design. Network latency is the time it takes for a clock to be propagated from the clock definition point in the design to a register clock pin. See Figure 2-3.

Figure 2-3 Source and Network Latency



The timing analysis tool provides two methods for representing clock latency. You can do either of the following:

- Allow the tool to compute latency by propagating the delays along the clock network. This
  method is very accurate, but it can be used only after clock tree synthesis has been
  completed.
- Estimate and specify explicitly the latency of each clock. You can specify this latency on individual ports or pins. Any register clock pins in the transitive fanout of these objects are affected and override any value set on the clock object. This method is typically used before clock tree synthesis.

# **Propagated Latency**

You can have the tool determine clock latency by propagating delays along the clock network. This process produces highly accurate results after clock tree synthesis and layout, when the cell and net delays along the clock network are all back-annotated or net parasitics have been calculated. The edge times of registers clocked by a propagated clock are skewed by the path delay from the clock source to the register clock pin.

To propagate clock network delays and automatically determine latency at each register clock pin, enter

```
prompt> set_propagated_clock [get_clocks CLK]
```

You can set the propagated clock attribute on clocks, ports, or pins. When set on a port or pin, it affects all register clock pins in the transitive fanout of the object.

To remove a propagated clock attribute, use the remove propagated clock command.

### Ideal Network Latency

Propagated latency calculation is usually inaccurate for prelayout design because the parasitics are unknown. For prelayout designs, you can estimate the latency of each clock and directly set that estimation with the set\_clock\_latency command. This method, known as ideal clocking, is the default method for representing clock latency.

The set\_clock\_latency command sets the latency for one or more clocks, ports, or pins. This is the command syntax:

```
set_clock_latency
[-rise] [-fall]
[-min] [-max]
[-source]
[-early] [-late]
[-clock clock_list]
delay
object_list
```

For example, to set the expected rise latency to 1.2 and the fall latency to 0.9 for CLK, enter

```
prompt> set_clock_latency -rise 1.2 [get_clocks CLK]
prompt> set_clock_latency -fall 0.9 [get_clocks CLK]
```

You must specify the delay value and the list of objects affected by the command. The object list can contain one or more clocks, ports, or pins.

Use the -rise or -fall option to restrict the latency setting to only rising or only falling edges of the clock. Otherwise, the setting applies to both rising and falling edges.

Use the -min or -max option to restrict the latency setting to only the minimum operating condition or only the maximum operating condition. Otherwise, the setting applies to all operating conditions.

The -source option sets source latency, rather than network latency, on the ports or pins specified in the object list. Use the -early and -late options in separate commands to specify different early and late latency values, as described in the next section.

The -clock option lets you specify the relevant clock when you set the latency on a port or pin and multiple clocks can pass through the port or pin.

The remove\_clock\_latency command removes user-specified clock network or source clock latency information from specified objects.

### **Source Latency**

Source latency is the latency from the ideal waveform to the source object in the design. You can specify source latency for both ideal and propagated clocks. The total latency at a register clock pin is the sum of the source latency and network latency.

To specify an external uncertainty for source latency, use the <code>-early</code> and <code>-late</code> options of the <code>set\_clock\_latency</code> command. For example, consider a source latency that can vary from 1.5 to 2.5 ns, as illustrated in Figure 2-4.

Figure 2-4 External Source Latency



To specify this type of source latency, you can use commands such as the following:

```
prompt> create_clock -period 10 [get_ports CLK]
prompt> set_clock_latency 1.5 -source -early [get_clocks CLK]
prompt> set_clock_latency 2.5 -source -late [get_clocks CLK]
```

The tool uses the more conservative source latency value (either early or late) for each startpoint and endpoint clocked by that clock. For example, for a setup check, it uses the late value for each startpoint and the early value for each endpoint. Figure 2-5 shows the early and late timing waveforms and the clock edges used for setup and hold analysis in the case where the startpoint and endpoint are clocked by the same clock.



Figure 2-5 Early/Late Source Latency Waveforms

# **Clock Uncertainty**

Setting clock uncertainty is a way to incorporate a margin of error in the design to account for possible variances in the clock propagation times in the post-layout design. Figure 2-6 illustrates the concept of clock uncertainty.

Figure 2-6 Clock Uncertainty



Circuit after logic synthesis

Circuit after clock tree synthesis and layout

You can specify the uncertainty or skew characteristics of clocks by using the set\_clock\_uncertainty command. The command specifies the amount of time variation in successive edges of a clock or between edges of different clocks arriving at sequential

devices. Before clock tree synthesis, clock uncertainty is caused by clock jitter, which is the variation in the clock edge times of the source clock, as well as clock skew, which is the difference in clock arrival times resulting from different propagation delays from the chip's clock pins to different sequential devices in the chip. After clock tree synthesis, with propagated latency, the tool separately accounts for uncertainty resulting from different propagation delays through the clock tree.

#### This is the command syntax:

```
set_clock_uncertainty
[object_list |
-from from_clock | -rise_from from_clock | -fall_from from_clock
-to to_clock | -rise_to to_clock | -fall_to to_clock]
[-rise] [-fall]
[-setup] [-hold]
uncertainty
```

You must specify the uncertainty time value and either an object list or "from" and "to" clocks. Specifying an object list invokes simple uncertainty for a clock, whereas specifying "from" and "to" clocks invokes interclock uncertainty between the two clocks.

Simple uncertainty is the variation in the generation of successive edges of a clock with respect to the exact, nominal times. Interclock uncertainty is the variation in skew between edges of different clocks. Figure 2-7 shows the difference between these two types of uncertainty.

Figure 2-7 Simple and Interclock Uncertainty



For simple uncertainty, you specify one or more objects, which can be clocks, ports, or pins. The uncertainty value applies to all capturing latches clocked by the specified clock or whose clock pins are in the fanout of the specified ports or pins.

For interclock uncertainty, you specify a "from" clock using the <code>-from</code>, <code>-rise\_from</code>, or <code>-fall\_from</code> option and a "to" clock the <code>-to</code>, <code>-rise\_to</code>, or <code>-fall\_to</code> option. The interclock uncertainty value applies to paths that start at the "from" clock and end at the "to" clock. Figure 2-8 shows the interclock skew between two clocks defined with the same period and waveform.

Figure 2-8 Example of Interclock Uncertainty



In performing a setup or hold check, the tool adjusts the timing check according to the worst possible difference in clock edge times. For example, for a setup check, it subtracts the uncertainty value from the data required time, thus requiring the data to arrive sooner by that amount, to account for a late launch and an early capture with the worst clock skew.

You can use set\_clock\_uncertainty to model clock network skew and set\_clock\_latency -source to model variations in the source clock delay, such as source clock jitter or off-chip clock skew.

When a path has both simple clock uncertainty and interclock uncertainty, the interclock uncertainty value is used. For example,

When the path is from CLKB to CLKA, the interclock uncertainty value 2 is used.

The following commands specify interclock uncertainty for all possible interactions of two clock domains. If you have paths from CLKA to CLKB and from CLKB to CLKA, you must specify the uncertainty for both directions, even if the value is the same. For example,

To set simple clock uncertainty (setup and hold) for all paths leading to endpoints clocked by U1/FF\*/CP, enter

```
prompt> set_clock_uncertainty 0.45 [get_pins U1/FF*/CP
```

To set a simple setup uncertainty of 0.21 and a hold uncertainty of 0.33 for all paths leading to endpoints clocked by CLK1, enter

```
prompt> set_clock_uncertainty -setup 0.21 [get_clocks CLK1]
prompt> set_clock_uncertainty -hold 0.33 [get_clocks CLK1]
```

To remove clock uncertainty settings, use the remove clock uncertainty command.

### **Ideal Clock Transition Times**

For propagated clocks, the tool calculates the clock transition time at each net. For ideal clocks, the default transition time is zero. To specify a nonzero transition time for an ideal clock, use the set\_clock\_transition command. This is the command syntax:

```
set_clock_transition
  transition_time
[-rise] [-fall]
[-min] [-max]
  clock_list
```

For example,

```
prompt> set_clock_transition 0.64 -fall [get_clocks CLK1]
```

The transition time value applies to all nets directly feeding sequential elements clocked by the specified clock.

Use the <code>-rise</code> or <code>-fall</code> option to specify a separate transition time for only rising or only falling edges of the clock. Use the <code>-min</code> or <code>-max</code> option to specify the transition time for minimum operating conditions or maximum operating conditions.

To cancel the effects of this command, use the remove\_clock\_transition command.

# **Reporting Clock Information**

The report\_clock command displays information about all clocks and generated clocks in the current design. For example,

```
prompt> report_clock
...
Attributes:

    d - dont_touch_network
    f - fix_hold
    p - propagated_clock
    G - generated_clock
```

| Clock                                | Period                        | Waveform                                 | Attrs           | Sources                                         |
|--------------------------------------|-------------------------------|------------------------------------------|-----------------|-------------------------------------------------|
| PCI_CLK SDRAM_CLK SD_DDR_CLK SYS_CLK | 15.00<br>7.50<br>7.50<br>8.00 | {0 7.5}<br>{0 3.75}<br>{0 3.75}<br>{0 4} | G               | <pre>{pclk} {sdram_clk} {sd_CK} {sys_clk}</pre> |
| Generated<br>Clock                   | Master<br>Source              | Generated<br>Source                      | Master<br>Clock | Waveform<br>Modification                        |
| SD_DDR_CLK                           | sdram_clk                     | {sd_CK}                                  | SDRAM_CLK       | divide_by(1)                                    |

Use the -skew option of report clock to report the uncertainty of the clocks.

# **Multiple Clocks**

When multiple clocks are defined for a design, the relationships between the clock domains depend on how the clocks are generated and how they are used in the design. The relationship between two clocks can be synchronous, asynchronous, or exclusive, as shown by the examples in Figure 2-9.



Figure 2-9 Synchronous, Asynchronous, and Exclusive Clocks

For the tool to analyze paths between different clock domains correctly, you might need to specify false paths between clocks, exclude one or more clocks from consideration during the analysis, or specify the nature of the relationships between different clocks.

# **Synchronous Clocks**

Two clocks are synchronous with respect to each other if they share a common source and have a fixed phase relationship. Unless you specify otherwise, the tool assumes that two clocks are synchronous if there is any path with data launched by one clock and captured by the other clock. The clock waveforms are synchronized at time zero, as defined by the create clock command. For example, consider the following create clock commands:

```
prompt> create_clock -period 4 -name CK1 -waveform {0 2}
prompt> create_clock -period 4 -name CK2 -waveform {1 3}
prompt> create_clock -period 6 -name CK3 -waveform {2 3}
```

The tool creates the clocks as specified in the commands, with the waveforms synchronized as shown in Figure 2-10. It adjusts the timing relationships further for any specified or calculated latency or uncertainty.

Figure 2-10 Synchronous Clock Waveforms



In a design that uses these three clocks, there might be paths launched by one clock and captured by another clock. When such paths exist, to test all possible timing relationships between different clock edges, the tool internally "expands" the clocks to the least common multiple of all synchronous clock periods, thus creating longer-period clocks with multiple rising and falling edges.

For example, the three clocks in the foregoing example have periods of 4, 4, and 6. The least common multiple of these periods, called the base period, is 12. To analyze the paths that cross the clock domains, the tool internally expands the clocks by repeating them over the base period. The resulting clock waveforms are shown in Figure 2-11. Each expanded clock has a period of 12.

Figure 2-11 Expanded Clock Waveforms



The tool checks timing paths between all edges in the expanded clocks. For example, the most restrictive setup check between a falling edge of CK2 and a rising edge of CK3 is from time=7 to time=8, as shown by the dashed arrow in Figure 2-11.

The report\_interclock\_relation command provides information about the common clock period used for paths between registers driven by different clocks. For example,

prompt> report\_interclock\_relation

. . .

| From       | Period1      | Count1 | To  | Period2      | Count2 | Common |
|------------|--------------|--------|-----|--------------|--------|--------|
| CK1<br>CK3 | 4.00<br>6.00 | 9      | CK3 | 6.00<br>4.00 | _      | 12.00  |

Each line of the report shows a pair of clocks: one that launches a timing path and one that captures the data at the end of the path. It also shows the periods and period multiplier of each clock, followed by the common multiple of the two periods used for timing analysis.

You should define multiple clocks in a manner consistent with the way they actually operate in the design. To declare clocks that are not synchronous, you can use case analysis or commands such as set\_clock\_groups -logically\_exclusive or set\_false\_path.

#### **Asynchronous Clocks**

Two clocks are asynchronous if they do not communicate with each other in the design. For example, a free-running, on-chip oscillator is asynchronous with respect to a system clock signal coming into the chip from the outside. Clock edges in the two clock domains can occur at any time with respect to each other.

You can declare the relationship between two clocks to be asynchronous. In that case, the tool does not check the timing paths launched by one clock and captured by the other clock. This is like declaring a false path between the two clocks. To declare an asynchronous relationship between two clocks, use the set\_clock\_groups -asynchronous command.

#### **Exclusive Clocks**

Two clocks are exclusive if they do not interact with each other. For example, a circuit might multiplex two different clock signals onto a clock line, one a fast clock for normal operation and the other a slow clock for low-power operation. Only one of the two clocks is enabled at any given time, so there is no interaction between the two clocks.

To prevent the tool from spending time analyzing the interaction between exclusive clocks, you can declare a false path between the clocks or use the set\_clock\_groups
-logically\_exclusive command to declare the clocks to be exclusive. Otherwise, you can use case analysis to disable the clock that you do not want to be considered.

To declare clocks CK1 and CK2 to be logically exclusive:

```
prompt> set_clock_groups -logically_exclusive -group {CK1} -group {CK2}
```

This causes the tool to ignore any timing path that starts from the CK1 domain and ends at the CK2 domain, or from the CK2 to the CK1 domain. This is like setting a false path from CK1 to CK2 and from CK2 to CK1. To find out about clock groups that have been set, use report\_clock -groups.

You can specify multiple clocks in each group. For example, to declare clocks CK1 and CK2 to be exclusive with respect to CK3 and CK4:

This causes the tool to ignore any path that starts in one group and ends in the other group.

If you specify more than two groups, each group is exclusive with respect to the other specified groups. For example,

If you specify just one group, that group is exclusive with respect to all other clocks in the design. For example,

```
prompt> set_clock_groups -logically_exclusive -group {CK1 CK2}
```

You can optionally assign a name to a clock group declaration, which makes it easier to later remove that particular declaration:

Use the remove\_clock\_groups command to remove a clock grouping declaration:

```
prompt> remove_clock_groups -logically_exclusive -name EX1
```

To remove all exclusive clock grouping declarations made with the set\_clock\_groups command:

```
prompt> remove_clock_groups -logically_exclusive -all
```

Clock groups can be physically exclusive as well as logically exclusive due to multiplexing of the clock signals or physical separation. There can be no crosstalk between physically exclusive clocks, as well as no logical interaction. In that situation, use the <code>-physically\_exclusive</code> option rather than <code>-logically\_exclusive</code>. This prevents the tool from attempting to perform crosstalk analysis between the clock nets.

For example, consider the circuit shown in Figure 2-12. Only one of the two input clocks is enabled at any given time.

Figure 2-12 Circuit with Multiplexed Clocks



To analyze both clocks at the same time, you can define them to be logically exclusive:

The <code>-logically\_exclusive</code> option causes the tool to suppress any logical (timing path) checking between CLK1 and CLK2. However, it still computes crosstalk delta delays across coupling capacitor x4 between the two clocks, which is pessimistic because the two clocks are never simultaneously present on the nets. To eliminate this pessimism, define the clocks to be physically exclusive:

Then the tool ignores any crosstalk between the nets of the physically exclusive clocks, as well as suppressing the logical checking between the clocks. This eliminates the pessimistic analysis of crosstalk between CLK2 and CLK1 across capacitor x4.

#### **Clock Sense**

The tool keeps track of inverters and buffers in clock trees. It recognizes the positive or negative sense of the clock signal arriving at each register clock pin. No specific action is necessary to specify the sense of a clock tree that has only buffers and inverters. In this case, the clock signal arriving at the register clock pin is said to be "unate."

A clock signal is "positive unate" if a rising edge at the clock source can only cause a rising edge at the register clock pin, and a falling edge at the clock source can only cause a falling edge at the register clock pin.

Similarly, a clock signal is "negative unate" if a rising edge at the clock source can only cause a falling edge at the register clock pin, and a falling edge at the clock source can only cause a rising edge at the register clock pin. In other words, the clock signal is inverted. See Figure 2-13.

Figure 2-13 Unate Clock Signals



A clock signal is not unate if the clock sense is ambiguous as a result of non-unate timing arcs in the clock path. For example, a clock that passes through an XOR gate is not unate because there are non-unate arcs in the gate. The clock sense could be either positive or negative, depending on the state of the other input to the XOR gate, as shown in Figure 2-14.

Figure 2-14 Non-Unate Clock Signals



The tool considers the output of the pulse generator at the bottom of Figure 2-14 to be non-unate because there are both inverting and non-inverting paths through the logic. The non-inverting path is the direct path through the AND gate and the inverting path is through the inverter.

To resolve this ambiguity for the tool, you can specify the sense of a clock signal at a point in the clock path using the set clock sense command. For example,

```
prompt> set_clock_sense -positive [get_pins xor1.z]
```

This command tells the tool to propagate only the positive unate paths through the output pin of the XOR gate, with respect to the original clock source. From that point onward, the tool keeps track of the sense of the signal through any subsequent buffers or inverters.

The positive unate setting applies to any clock that passes through the specified pin. If multiple clocks can reach that pin, you can restrict the setting to certain clocks, as in the following example:

The set\_clock\_sense setting has an effect only in the non-unate part of a clock network. If the command is applied to a pin in a unate section of the clock network and the requested sense disagrees with the actual sense, it generates an error message and the setting is ignored.

Specifying the clock sense at a point in the design uses one of the following forms of syntax:

```
set_clock_sense -positive object_list
set_clock_sense -negative object_list
```

The object list specifies the pins in the design where the sense is being defined. If multiple clocks pass through the objects, you can specify the clocks affected by the command by using the <code>-clock</code> option. To reverse the effects of <code>set\_clock\_sense</code>, use the <code>remove clock sense</code> command.

Figure 2-15 shows some examples of clock-modifying circuits and the corresponding clock senses.

Figure 2-15 Clock Sense Examples



To stop clock propagation forward from a specified pin, use the <code>-stop\_propagation</code> option of the <code>set\_clock\_sense</code> command. This stops propagating those clocks specified in the clock list from the specified pins or cell timing arcs in the <code>object\_list</code>.

#### **Pulse Clocks**

A pulse clock consists of a sequence of short pulses whose rising and falling edges are both triggered by the same edge of another clock. Pulse clocks are often used to improve performance and reduce power consumption.

To analyze the timing of a circuit containing pulse clocks, the tool needs information about the timing characteristics of the clock. There are three ways to provide this information:

- Use a pulse generator cell that has been characterized with pulse generator attributes in the .lib description.
- Use the <code>create\_generated\_clock</code> command to describe the pulse timing with respect to the source clock.
- Use the set\_clock\_sense command to specify the sense of the generated pulses with respect to the source clock.

The best method is to use a pulse generator cell that has been characterized in its .lib library description. In that case, no additional action is necessary to specify the pulse clock characteristics. For information about specifying the pulse generator characteristics of a library cell, see the Library Compiler documentation.

If characterized pulse generator cells are not available in the library, you must specify the pulse clock characteristics at each pulse generation point in the design, using either the <code>create\_generated\_clock</code> or <code>set\_clock\_sense</code> command. Using the <code>create\_generated\_clock</code> command creates a new clock domain at a pulse generation point. Using <code>set\_clock\_sense</code> does not create a new clock domain, but merely specifies the sense for an existing clock downstream from the specified point. For example, consider the pulse clock circuit shown in Figure 2-16.

CLK edge number

1 2 3

CLK CLKB

CL

Figure 2-16 Pulse Clock Specified as a Generated Clock

Edge number 1 of the source triggers both the rising and falling edges of the pulse clock. The pulse width is determined by the delay of the inverter.

To specify the generated pulse clock CLKP as a generated clock:

Specifying the generated clock as a pulse clock using repeated edge digits ensures correct checking of delays between the source clock and the pulse clock.

The position of the repeated digit determines whether an active-high or active-low pulse is generated, and the edge number that is repeated determines the type of edge in the master clock used to trigger the pulse, as follows:

- -edges {1 1 3} -- rising edge of source triggers high pulse
- -edges {2 2 4} -- falling edge of source triggers high pulse
- -edges {1 3 3} -- rising edge of source triggers low pulse
- -edges {2 4 4} -- falling edge of source triggers low pulse

Instead of using the <code>create\_generated\_clock</code> command to define a new clock, you can use the <code>set\_clock\_sense</code> command to specify the sense of the existing clock:

This command specifies that the clock at the output of the AND gate is a pulse that rises and falls on the rising edge of the source clock. The pulse clock is not defined as a separate clock domain. Instead, it is just a different sense of the source clock downstream from the specified point in the clock network, and that sense is the "rise-triggered high pulse" sense.

In general, the clock sense of a pulse clock can be specified at a location in the design by one of the following forms of syntax:

```
set_clock_sense -pulse rise_triggered_high_pulse object_list
set_clock_sense -pulse rise_triggered_low_pulse object_list
set_clock_sense -pulse fall_triggered_high_pulse object_list
set_clock_sense -pulse fall_triggered_low_pulse object_list
```

The nominal width of the generated pulses is zero whether you use a pulse generator cell defined in the library, the <code>create\_generated\_clock</code> command, or the <code>set\_clock\_sense</code> command. To determine the actual pulse width, the tool considers the different rise and fall latency values at the pulse generator output pin:

```
(high pulse width) = (fall network latency) - (rise network latency)
(low pulse width) = (rise network latency) - (fall network latency)
```

You can use the set\_clock\_latency command to specify the latency values (and therefore the pulse width) explicitly for an ideal clock, or you can allow the tool to calculate the propagated latency from the circuit for a propagated clock. For example, to set an ideal pulse width to 0.5 for high pulses, for all registers downstream from pin and2/z, and with an overall latency of 0.6, the commands would be:

```
prompt> set_clock_latency -rise 0.6 [get_pins and2.z]
prompt> set_clock_latency -fall 1.1 [get_pins and2.z]
```

# **Clock-Gating Signal Timing Checks**

A gated clock signal occurs when a clock network contains logic other than inverters or buffers. For example, if a clock signal acts as one input to a logical AND function and a control signal acts as the other input, the output is a gated clock signal. See Figure 2-17.

Figure 2-17 Gated Clock



The tool does not automatically check setup and hold violations on the gating signals of clock-gated cells. It is possible for these signals to undergo transitions while clock pulses are passing through the gating cells. This can lead to both clipped and spurious clock pulses.

To check for such conditions, use the  $set\_clock\_gating\_check$  command. This is the command syntax:

```
set_clock_gating_check
  [-setup setup_margin]
  [-hold hold_margin]
  [-rise] [-fall]
  [-high [-low]
  [object_list]
```

Using this command, you can specify setup and hold margins to control gating signal transitions. Use the <code>-setup</code> option to ensure that the clock-gating input is stable for a given time interval before the clock input of the gating cell changes to a noncontrolling value. Similarly, use the <code>-hold</code> option to ensure that the clock-gating signal remains stable for a given time interval after the clock input returns to a controlling value. Used together, the two checks ensure that the clock-gating signal is stable for the entire period of time during which the gated clock input has a noncontrolling value.

If you want only the rising or only the falling delays constrained by the set\_clock\_gating\_check command, use the -rise or the -fall option, respectively. If you do not specify either of these options, both types of delays are constrained.

You can list the design objects on which clock-gating setup and hold margins are to be checked, such as designs, cells, pins, or clock objects. Multiplexer cells are supported. Also, when you specify a clock object, all clock-gating cells in the given clock's network are checked. If you do not specify any design objects, the clock-gating check is applied to the current design.

In the case of certain cells that the tool cannot analyze, you must designate the noncontrolling value of the clock. Use the <code>-high</code> or <code>-low</code> option to define the noncontrolling clock value as high or low, respectively. You can use these options only with cells or pins.

The tool handles clock-gating checks like other timing constraints and tries to adjust the delays of the logic driving the gating inputs to avoid setup and hold violations. During optimization, Design Compiler can change only the size of cells with clock-gating checks. The logic functions of such cells are preserved and no other logic transformations are allowed.

Clock-gating checks can be performed only between a clock signal and a nonclock signal, not between two clock signals or between two nonclock signals.

If you decide that clock-gating checks are no longer needed, you can remove them with the remove\_clock\_gating\_check command. This command has the same options as the set\_clock\_gating\_check command.

In Figure 2-18, the <code>set\_clock\_gating\_check</code> command can be used to define the setup and hold margins shown at the AND and NAND clock-gating cells. The setup margin is measured relative to the rising transition of the gating cell's clock input. The hold margin is measured from the falling transition of the clock input.

Figure 2-18 Setup and Hold Margins for AND and NAND Gates



Figure 2-19 shows setup and hold margins for OR and NOR clock-gating cells. The setup margin is measured relative to the falling transition of the gating cell clock input. The hold margin is measured relative to the rising transition of the clock input.

Figure 2-19 Setup and Hold Margins for OR and NOR Gates



Figure 2-20 shows examples of distorted clock waveforms that might be caused by invalid changes on the clock-gating inputs in the absence of clock-gating checks.

CLOCK
GATE
GATED\_CLOCK

No change interval
Clipped clock pulse
GATED\_CLOCK

CATE
GATE
GATE
GATED\_CLOCK

Figure 2-20 Distorted Clock Waveforms

#### **Example 1**

To specify a setup requirement of 0.2 and a hold requirement of 0.4 on all gates in the clock network of CLK1, enter

prompt> set\_clock\_gating\_check -setup 0.2 -hold 0.4 CLK1

#### Example 2

To specify a setup requirement of 0.5 on gate and 1, enter

prompt> set\_clock\_gating\_check -setup 0.5 and1

You can disable clock-gating checks on specific cells and pins. Use the set\_disable\_clock\_gating\_check command to list the cells and pins you want the clock-gating check to ignore. To re-enable the clock-gating check on disabled cells or pins, use the remove\_disable\_clock\_gating\_check command.

#### **Generated Clocks**

A design might include clock dividers or other structures that produce a new clock from a master source clock. A clock that is generated by on-chip logic from another clock is called a generated clock.

Figure 2-21 shows an example of a divide-by-2 generated clock. the waveforms of the master and generated clock for a divide-by-2 clock generator. The clock waveform is ideal, with no clock-to-Q delay.

Figure 2-21 Divide-by-2 Clock Generator



The tool does not derive the behavior of the generated clock from the logic, so you must specify the behavior as a separate clock. You can do so with the <code>create\_clock</code> command. However, there are certain advantages to using the <code>create\_generated\_clock</code> command instead.

The create\_generated\_clock command specifies the characteristics of an internally generated clock in terms of the master clock. You specify one or more source objects in the design where the generated clock exists, a pin where the master clock exists, and the time relationship between the master clock and the generated clock, such as divide-by-2. The tool determines the generated clock characteristics based on the master clock. If the period or latency of the master clock changes, the generated clock also changes accordingly.

To remove a generated clock definition, use the remove\_generated\_clock command.

#### **Divide-by-2 Generated Clock**

To specify a divide-by clock, use the <code>-divide\_by</code> option of the <code>create\_generated\_clock</code> command and specify the frequency division factor. For example, to create the divide-by-2 generated clock in Figure 2-21 shown previously, specify 2 as the frequency division factor:

Specify a port or a pin (not a clock name) as the master source from which the new clock is generated. Specify a pin as the creation point for the new generated clock.

Note that generated clock edges are based on occurrences of rising edges at the master clock source pin (specified with the <code>-source</code> option). If you need to create a generated clock based on falling edges at the master clock source pin, use the <code>-edges</code> option rather than the <code>-divide\_by</code> option (see "Divide-by Clock Based on Falling Edges" on page 2-31).

#### **Generated Clock Based on Edges**

You can use <code>create\_generated\_clock</code> -edges to specify the generated clock in terms of edges of the master clock waveform on the master pin. For example, consider the clock generator circuit shown in Figure 2-22.

Figure 2-22 Divide-by-3 Clock Generator



create\_clock -period 2 -name SYSCLK [get\_ports SYSCLK]



The generated clock signal DIV3A has a period three times longer than the master clock, with an asymmetrical waveform. To specify this waveform, you can enter

# **Divide-by Clock Based on Falling Edges**

If you need to create a generated clock based on falling edges at the master clock pin, use the <code>create\_generated\_clock</code> command with the <code>-edges</code> option. The generated clock examples in Figure 2-23 demonstrate how to do this.

DIV2A DIV2B D Q Q QN QN **SYSCLK** FF1 FF2 Ζ U1 **SYSCLK** DIV2A DIV2B Clock edge 2 3

Figure 2-23 Generated Divide-by-2 Clocks Based on Different Edges

The generated clock DIV2A is based on the rising edge of the master clock at the SYSCLK port, so you can specify the generated clock using either the <code>-divide\_by</code> option or the <code>-edges</code> option:

The generated clock DIV2B is based on the falling edge of the master clock at the SYSCLK port, so you cannot use the <code>-divide\_by</code> option. However, you can still use the <code>-edges</code> option:

Another way to specify DIV2B is to use a different source pin:

# **Shifting the Edges of a Generated Clock**

You can shift the edges of a generated clock by a specified amount of time. This shift is not considered clock latency. For example, consider the clock generator circuit shown in Figure 2-24.

Figure 2-24 Generated Divide-by-3 Clock With Shifted Edges



To specify the master source clock and the two generated clocks, you could use commands such as the following:

The report clock command reports the specified clocks as follows:

```
p - propagated_clock
G - Generated clock
```

| Clock                 | Period               | Waveform                          | Attrs  | Sources                      |
|-----------------------|----------------------|-----------------------------------|--------|------------------------------|
| CLK<br>DIV3B<br>DIV3C | 2.20<br>6.60<br>6.60 | {0 1.1}<br>{2.2 4.4}<br>{4.4 6.6} | G<br>G | {SYSCLK}<br>{U3/Q}<br>{U4/Q} |

| Generated | Master | Generated | Waveform                              |
|-----------|--------|-----------|---------------------------------------|
| Clock     | Source | Source    | Modification                          |
| DIV3B     | MYCLK  | U3/Q      | edges(359) edges(359) shifts(2.22.22) |
| DIV3C     | MYCLK  | U4/Q      |                                       |

# **Combinational-Only Source Latency Calculation**

During timing analysis, when the tool calculates clock source latency of a generated clock, it traces both combinational and sequential paths between the source pin of a generated clock and the source pin of its master clock. A sequential path is any path containing a register clock pin, a data pin of a transparent latch, or a generated clock definition point other than the final pin in the path.

In some situations, you might want the tool to avoid these sequential paths when it is calculating clock latency. For example, in Figure 2-25, the generated clock CLK\_INV is specified by using the following command:

Figure 2-25 Paths in a Generated Clock Source Network



To have the tool avoid sequential paths, use the -combinational option with the create\_generated\_clock command. For example,

When you specify this option, the generated clock has the same period as the master clock. You can use the <code>-combinational</code> option only for those generated clocks that are frequency-divided (<code>-divide\_by 1 option</code>) or frequency-multiplied (<code>-multiply\_by 1)</code> generated clocks of the master clock. You cannot use this option for edge-derived clocks (<code>-edges option</code>).

#### Generated Clock Based on a Non-Unate Master Clock

A clock signal is not unate if the clock sense is ambiguous as a result of non-unate timing arcs in the clock path. For example, a clock that passes through an XOR gate is not unate because there are non-unate arcs in the gate.

The tool considers the output of the multiplexer in Figure 2-26 to be non-unate because there are both inverting and non-inverting paths through the logic. The non-inverting path is the direct path through the MUX and the inverting path is through the inverter. By default, the tool propagates both positive unate clock paths and negative unate clock paths through the non-unate clock network.

Figure 2-26 Non-Unate Clock Paths



The clock network starting from the convergent point sees both the positive and negative sense of the original clock. The tool keeps track of clock properties of both senses separately. For example, when the positive sense clock has a waveform of {0 5}, the negative sense clock has a waveform of {5 10}.

In general path analysis, the particular path is constrained by the most constraining sense of the non-unate clock. When you need to generate clocks based on the non-unate master clock (for example, a divide-by-2 clock), new clocks generated by the create\_generated\_clock command are based on the original clock wave form. To generate a clock based on the expanded wave form (inverted clock of the divide-by-2 clock), use the create\_generated\_clock -invert command.

To specify the negative sense before waveform expansion (divide-by-2 clock of the negative unate master clock), you can include the <code>-preinvert</code> option with the <code>create\_generated\_clock</code> command. Note that the generated source has to be a pin in the fanout of the non-unate clock in order for the correct waveform expansion to occur. Consider Figure 2-26. Example 2-1 shows how to use the <code>-preinvert</code> and <code>-invert</code> options when a generated clock is driven by a non-unate master clock. Figure 2-27 shows the resulting waveforms.

Example 2-1 Specifying Generated Clocks Based on a Non-Unate Master Clock

```
create_generated_clock -divide_by 2 -source \
    [get_pins FF1/CLK] -name gclk_pos [get_pins FF1/Q]

create_generated_clock -divide_by 2 -source \
    [get_pins FF1/CLK] -name gclk_neg \
    [get_pins FF1/Q] -preinvert

create_generated_clock -divide_by 2 -source
    [get_pins FF1/CLK] -name glk_inv
    [get_pins FF1/Q] -invert
```



Figure 2-27 Waveforms Resulting from -preinvert and -invert

# **Estimated I/O Latency**

You model the timing context of a design within a larger system by using input and output delays. You use the <code>set\_input delay</code> command to model the external delay at an input port; you use the <code>set\_output\_delay</code> to model the external delay from an output port to a sequential device.

Prior to clock tree synthesis, when calculating the arrival time at an input port or departure time from an output port, the tool adds the clock source latency and clock network latency to the external datapath delays. However, after clock tree synthesis, when clocks are defined as propagated, the ideal clock network latency is replaced by propagated latency. Propagated clocks automatically calculate clock network latency within the design; however, clock network latency external to your design is not known. This network latency at input ports and output ports is known as I/O latency.

Figure 2-28 I/O Latency



As illustrated in Figure 2-28, for input paths, the tool uses the propagated network latency for capture clocks in the current design but does not know the propagated network latency for launch clocks. In a similar manner, for output paths, the tool uses the propagated network latency for launch clocks but does not know the propagated network latency for capture clocks.

To account for clock network latency in external delays, you can set the <code>estimate\_io\_latency</code> variable to true. When this variable is set to true, the tool assigns clock network delay to every input or output port. The tool assumes that clock tree synthesis balances network latency across different clocks. Based on this assumption, the tool estimates off-chip clock latency with reference to the synthesized clock tree in the current design.

If you used the <code>-network\_latency\_included</code> option with the <code>set\_input\_delay</code> command or <code>set\_output\_delay</code> command, the tool does not use an estimated I/O latency. Using the <code>-network\_latency\_included</code> option tells the tool that the clock network latency of the related clock is included in the input or output delay. The ideal way to model external network

latency is to add the delay to the external delay and use the <code>-network\_latency\_included</code> option. Using the <code>estimate\_io\_latency</code> variable gives a reasonable representation if the clock network latency is balanced across different clocks.

#### Calculating I/O Latency for Input Paths

For each input delay, the tool locates the registers at the fanout of the input port. For setup analysis, the tool adds the smallest propagated clock network latency for any register in the fanout set to the arrival time. For hold analysis, it adds the largest network latency of any register in the fanout set to the arrival time. The latency that the tool selects can be associated with any clock and not necessarily the clock referenced by the input delay.

For example, in Figure 2-28 on page 2-38, for setup analysis, the tool uses an estimated I/O latency of 0.56, which is the smallest propagated clock network latency for the fanout registers of IN. Use the report\_timing command to view the estimated I/O latency value. Here is a typical report\_timing report showing the estimated input latency.

Startpoint: in (input port clocked by clk3)
Endpoint: FF2 (rising edge-triggered flip-flop clocked by clk2)
Path Group: clk2
Path Type: max

| Point                                                                                                                                                        | Incr | Path                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------------------------|
| clock clk3 (rise edge) clock source latency estimated IO latency input external delay in (in) U1/Z (IVA) U2/Z (IVA) U3/Z (IVA) FF2/D (FD1) data arrival time | 1.00 | 16.56 f<br>16.90 r<br>17.24 f<br>17.70 r |
| clock clk2 (rise edge) clock network delay (ideal) FF2/CP (FD1) library setup time data required time                                                        |      |                                          |
| slack (VIOLATED)                                                                                                                                             |      | -6.50                                    |

# **Calculating I/O Latency for Output Paths**

For each output delay, the tool locates the registers in the fanin of the output port. For setup analysis, the tool adds the largest propagated clock network latency for any register in the fanin set to the data required time. For hold analysis, it adds the smallest network latency of any register in the fanin set to the data required time. The latency that the tool selects can be associated with any clock and not necessarily the clock referenced by the output delay.

For example, in Figure 2-28 on page 2-38, for setup analysis, the tool uses an estimated I/O latency of 1.70, which is the largest propagated clock network latency for the fanin registers of OUT. Use the report\_timing command to view the estimated IO latency value. Here is a typical report\_timing report showing the estimated output latency.

```
Startpoint: FF2 (rising edge-triggered flip-flop clocked by clk2)
Endpoint: out1 (output port clocked by clk1)
Path Group: clk1
Path Type: max
```

| Point                                                                                                                          | Incr                                         | Path                                    |
|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------------|
| <pre>clock clk2 (rise edge) clock network delay (ideal) FF2/CP (FD1) FF2/Q (FD1) A1/Z (AN3) out1 (out) data arrival time</pre> | 8.00<br>4.00<br>0.00<br>1.42<br>0.85<br>0.00 | 12.00 r<br>13.42 f                      |
| <pre>clock clk1 (rise edge) clock source latency estimated IO latency output external delay data required time</pre>           | 10.00<br>3.00<br><b>1.70</b><br>-3.00        | 10.00<br>13.00<br><b>14.70</b><br>11.70 |
| data required time data arrival time                                                                                           |                                              | 11.70<br>-14.27                         |
| slack (VIOLATED)                                                                                                               |                                              | -2.57                                   |

# **Propagated Clocks**

Setting a propagated clock is appropriate after layout, when the design has actual clock trees and annotated delay or parasitics. If you do not set a propagated clock, the tool assumes ideal clocking. Ideal clocking means that clock networks have a specified latency (from the set\_clock\_latency command) or zero latency by default. You specify propagated clock latency after layout; you specify ideal clock latency before layout to provide an estimate of the clock tree.

Thus, after layout, you do not need to estimate the clock tree uncertainty or network latency any more, although you still need to specify source latency. Additionally, you no longer need to specify the clock transition.

For example, as part of the pre-layout process, you might specify the following commands:

```
prompt> set_clock_latency -max 0.8 clk
prompt> set_clock_latency -min 0.3 clk
```

Alternatively, you might use back-annotation to approximate the expected delay, in which case you would back-annotate Standard Delay Format (SDF) values. For example, as part of the pre-layout process, you might specify the following commands:

```
prompt> set_propagated_clock clk
prompt> read sdf -max type max -min type min design.sdf
```

The set\_propagated\_clock command specifies propagated clock latency for the listed clocks, ports, pins, and cells. For information about the read\_sdf command, see "Back-Annotating Timing Information from an SDF File" on page 6-3. See the man pages for the complete description of the set\_propagated\_clock and read\_sdf commands.

Registers clocked by a propagated clock have their edge times skewed by the path delay from the clock source to the register clock pin.

To set a propagated clock,

1. Remove clock transitions, which you set previously with the set\_clock\_transition command. Enter

```
prompt> remove clock transition CLKA
```

2. Remove network latency, which you set previously with the set\_clock\_latency command. (Propagated clocks automatically calculate network latency; however, you still need to specify source latency.) Enter

```
prompt> remove_clock_latency CLKA
```

3. Modify the clock uncertainty to model clock jitter but not clock skew. (Propagated clocks automatically calculate skew.) Enter

```
prompt> set_clock_uncertainty 0.1 CLKA
```

4. Set propagated clocks. Enter

```
prompt> set_propagated_clock CLKA
```

Table 2-1 summarizes the clock-related commands you would use before and after layout.

Table 2-1 Clock-Related Commands to Use Before and After Layout

| Pre-layout commands              | Post-layout commands             |
|----------------------------------|----------------------------------|
| create_clock -p 30 -n ClkA Clk   | create_clock -p 30 -n ClkA Clk   |
| set_clock_uncertainty 0.5 ClkA   | set_clock_uncertainty 0.1 ClkA   |
| set_clock_transition 0.25 ClkA   | remove_clock_transition ClkA     |
| set_clock_latency -source 4 ClkA | set_clock_latency -source 4 ClkA |
| set_clock_latency 2 ClkA         | remove_clock_latency ClkA        |
|                                  | set_propagated_clock ClkA        |

For more information, see the set\_propagated\_clock man page.

To remove propagated clocks that you set with the set\_propagated\_clock command, use the remove\_propagated\_clock command.

# 3

# Timing Paths

A timing path is a point-to-point sequence through a design that starts at a register clock pin or an input port, passes through combinational logic elements, and ends at a register data input pin or an output port. For an overview of timing path principles, see Chapter 1, "Introduction to Synthesis Timing," which includes basic information about path startpoints and endpoints, delay calculation, setup and hold constraints, and time borrowing.

This chapter provides information about timing paths in the following sections:

- Path Groups
- Path Specification Methods
- Default Path Delay Constraints
- Timing Exceptions
- Data-to-Data Checks

# **Path Groups**

The synthesis tool organizes timing paths into groups. The grouping of paths affects the optimization of the design and the generation of timing reports. By default, there is one path group for each clock in the design. All timing paths clocked by a given clock at the path endpoint belong to that clock's path group.

The tool also creates a path group called \*\*default\*\* (including the asterisks). The \*\*default\*\* group contains any paths that cannot be categorized by the clock used at the path endpoint, such as feedthrough and asynchronous paths. Paths can be moved to the \*\*default\*\* group by using the remove\_path\_group command or the -default option of the group\_path command.

You can specify clock-gating checks by using the <code>set\_clock\_gating\_check</code> command. A clock-gating path ends on a combinational element used for gating the clock. By default, clock-gating paths are contained in the path group of the clock being gated. However, you can have the synthesis tool create a separate <code>\*\*clock\_gating\_default\*\*</code> group to contain the clock-gating paths, for both optimization and reporting purposes. To do so, set the variable <code>timing\_separate\_clock\_gating\_group</code> to true. Using this option matches the default behavior of PrimeTime with respect to the grouping of clock-gating paths. PrimeTime also creates a path group called <code>\*\*async\_default\*\*</code>, which is not supported by the synthesis tools.

#### **User Grouping of Paths**

All timing paths within a path group are optimized for timing together, starting with the critical path. Paths within a group are optimized and reported separately from other groups. You can use the <code>group\_path</code> command to assign paths to existing groups or new groups that you create, which lets you control the focus of optimization effort and the reporting of paths. For details, see "Path Groups" on page 1-31.

To get information about the current set of path groups, use the <code>report\_path\_group</code> command. To remove a path group, use the <code>remove\_path\_group</code> command. Paths belonging to a removed group are implicitly assigned to the default path group.

# **Weight or Cost Function**

You can optionally assign a weight or cost function to each path group so that the synthesis tool applies more effort to optimizing the targeted group. The default weighting value for each path group is 1. You specify a different weighting value by using the <code>-weight</code> option of the <code>group\_path</code> command. The higher the weighting, the higher the effort applied to the group. For example, higher weighting for a group means that the synthesis tool will attempt to reduce the size of a timing violation for a path in that group at the expense of slack in a lower-weighted group. For details, see "Path Groups" on page 1-31.

# **Critical Range**

A synthesis tool continuously works to improve the timing of paths leading to the most critical endpoint. The most critical endpoint changes as the paths are improved. Sometimes it is not possible for to tool to optimize all paths to zero slack. By default, when the synthesis tool determines that it cannot further improve the most critical endpoint, it stops delay optimization for that path group and proceeds with the next path group, leaving some paths with timing violations.

The default behavior can be changed by setting the *critical range* of one or more path groups. The critical range specifies the range of timing slacks that the synthesis tool attempts to correct beyond the first critical path that cannot be optimized further. The default critical range is zero, which means that the synthesis tool does not attempt to optimize any more paths in a path group after it stops working on the most critical path.

With an nonzero critical range, the synthesis tool continues working to optimize near-critical paths that have a timing slack within the specified range of the current critical path, up to one additional path per endpoint. It continues to work on path endpoints within the path group as long as their timing slacks are negative and within the specified range of the first critical path that could not be optimized further.

The larger the critical range, the larger the number of paths that the tool attempts to fix, at the cost of more runtime. If you set the critical value to a large number, the tool attempts to optimize all paths that have timing violations, subject to the limit of one path per endpoint. If you want to optimize multiple paths to the same endpoint, you must group those paths into separate path groups with the group\_path command.

You can set the critical ranges for individual path groups by using the <code>-critical\_range</code> option of the <code>group\_path</code> command. To set a general critical range for all path groups, use the <code>set\_critical\_range</code> command. A specific critical range setting made with the <code>group\_path -critical\_range</code> command has higher priority than a general setting made with the <code>set critical range</code> command.

# **Reporting Path Groups**

The report\_path\_group command displays information about the path groups in the current design, including the name, weight, critical range, and endpoint clock for each group. For example,

```
prompt> report_path_group
...
```

|                                       | Group Name                                       | Weight               | Critical<br>Range    |  |  |  |
|---------------------------------------|--------------------------------------------------|----------------------|----------------------|--|--|--|
|                                       | **default** PCI_CLK SDRAM_CLK SD_DDR_CLK SYS_CLK | 1.00<br>1.00<br>1.00 | 0.00<br>0.00<br>0.00 |  |  |  |
|                                       | Path Group PCI_CLK: -to PCI_CLK                  |                      |                      |  |  |  |
|                                       | Path Group SDRAM_CLK: -to SDRAM_CLK              |                      |                      |  |  |  |
| Path Group SD_DDR_CLK: -to SD_DDR_CLK |                                                  |                      |                      |  |  |  |
|                                       | Path Group SY<br>-to                             | S_CLK:<br>SYS_CL     | K                    |  |  |  |
|                                       | 1                                                |                      |                      |  |  |  |

# **Path Specification Methods**

The report\_timing command, the group\_path command, and the timing exception commands (such as set\_false\_path) operate on one or more timing paths that you specify in the command. The most straightforward way to specify paths is to provide the startpoint and endpoint. The startpoint is known as the "from" object and the endpoint is called the "to" object. The following examples demonstrate the command syntax:

```
prompt> report_timing -from PORTA -to PORTZ
prompt> set_false_path -from FFB1/CP -to FFB2/D
prompt> set_max_delay -from REGA -to REGB 12
prompt> set_multicycle_path -setup 2 -from FF4 -to FF5
```

The "from" startpoint object can be a clock, a primary input port, a sequential cell, the clock input pin of a sequential cell, a data pin of a level-sensitive latch, or a pin that has an input delay specified. If you specify a clock, all registers and primary inputs related to that clock are used as path startpoints. If you specify a cell, the command applies to one path startpoint on that cell.

The "to" endpoint object can be a clock, a primary output port, a sequential cell, the data input pin of a sequential cell, or a pin that has an output delay specified. If you specify a clock, all registers and primary outputs related to that clock are used as path endpoints. If you specify a cell, the command applies to one path endpoint on that cell.

There can be many paths originating from the "from" object and ending at the "to" object. All such paths are selected for action by the command. The report\_timing command analyzes all the specified path. By default, it reports only the single path having the worst slack among those analyzed. In a command that sets a timing exception, all the selected paths are affected by the command.

You can restrict the command to only to rising edges or only falling edges by using the command arguments <code>-rise\_from</code>, <code>-fall\_from</code>, <code>-rise\_to</code>, and so on. For example, <code>-rise\_from</code> applies only to rising edges at the startpoint object.

#### **Through Arguments**

To restrict the scope of paths selected for action, you can use the -through option, as in the following example:

```
prompt> report timing -from PORTA -through FFB1 -to PORTZ
```

This selects the paths that start at PORTA, pass through FFB1, and end at PORTZ.

You can use <code>-through</code> alone, without <code>-from</code> or <code>-to</code>, to specify all paths that pass through one or more specific pins, ports, or cells. However, this method is more computationally intensive, especially in larger designs. Whenever possible, it is better to use <code>-from</code> or <code>-to</code> (or both) to specify the paths.

You can use multiple -through, -rise\_through, and -fall\_through arguments in a single command to specify a group of paths. For example,

```
prompt> report_timing -from A1 -through B1 -through C1 -to D1
```

This means any path that starts at A1, passes through B1 and C1 in that order, and ends at D1.

Multiple objects in braces mean any one object in the list satisfies the "through" condition. For example,

```
prompt> report_timing -from A1 -through {B1 B2} -through {C1 C2} -to D1
```

This means any path that starts at A1, passes through either B1 or B2, then passes through either C1 or C2, and ends at D1.

#### Rise/Fall From/To Clock

You can restrict the command to only to rising edges or only falling edges by using the command arguments <code>-rise\_from</code>, <code>-fall\_from</code>, <code>-rise\_to</code>, and so on. When the "from" or "to" object is a clock, the command specifies paths based on the launch of data at startpoints or the capture of data at endpoints for a specific edge of the source clock. The path selection considers any logical inversions along the clock path.

For example, the <code>-rise\_to</code> <code>clock</code> option specifies each path clocked by the specified clock at the endpoint, where a rising edge of the source clock captures data at the path endpoint. This can be a rising-edge-sensitive flip-flop without an inversion along the clock path, or a falling-edge-sensitive flip-flop with an inversion along the clock path. The data being captured at the path endpoint does not matter.

The following examples demonstrate the behavior with the set\_false\_path command. Consider the circuit shown in Figure 3-1. FF1, FF2, FF5, and FF6 are rising-edge-triggered flip-flops; and FF3, FF4, FF7, and FF8 are falling-edge-triggered flip-flops. FF1 through FF4 are clocked directly, whereas the FF5 through FF8 are clocked by an inverted clock signal.



Figure 3-1 Circuit for Path Specification Examples 1 Through 3

#### Example 1

prompt> set\_false\_path -to [get\_clocks CLK]

In Figure 3-1, all paths clocked by CLK at the path endpoint (all four paths) are declared to be false.

#### Example 2

prompt> set\_false\_path -rise\_from [get\_clocks CLK]

In Figure 3-1, all paths clocked by CLK at the startpoint that have data launched by a rising edge of the source clock are declared to be false, so Path A and Path D are false.

#### Example 3

prompt> set\_false\_path -fall\_to [get\_clocks CLK]

In Figure 3-1, all paths clocked by CLK at the endpoint that capture data on a falling edge of the source clock are declared to be false, so Path B and Path C are false.

#### **Example 4**

Consider the circuit shown in Figure 3-2. The two flip-flops latch data on the rising edge of the clock. The level-sensitive latch opens on the rising edge and closes on the falling edge of the clock.

Figure 3-2 Circuit for Path Specification Example 4



Using -rise\_from clock option of the report\_timing command reports the paths with data launched by a rising edge of the clock, from data to FF0, from FF0 to LAT1, from LAT1/D to FF1, from LAT1/G to FF1, and from FF1 to out:

prompt> report\_timing -rise\_from [get\_clock clk] -nworst 100

Using the <code>-fall\_to</code> option in the command instead reports the path with data captured by a falling edge of the clock, which is from <code>FF0</code> to <code>LAT1</code>:

prompt> report\_timing -fall\_to [get\_clock clk] -nworst 100
Example 5

In the circuit shown in Figure 3-3, multiple clocks reach the flip-flop.

Figure 3-3 Circuit for Path Specification Example 8



Suppose that you want to set false path ending at the D pin of the flip-flop, but only for clk1, not for clk2. You can do this by using the -through and -to options:

```
prompt> set_false_path -through FF1/D -to [get_clocks clk1]
```

To set false path ending at the D pin of the flip-flop, but only paths that capture data on the rising edge of clk1:

prompt> set\_false\_path -through FF1/D -rise\_to [get\_clocks clk1]

# **Default Path Delay Constraints**

In the absence of timing exceptions, the tool checks for data arrival at the next capture clock edge following the launch event. For a single-clock design, launch occurs on a clock edge and capture occurs at the next clock edge. When the launch and capture clocks are different, the tool considers the nearest possible capture clock edge that can occur after the launch clock edge.

# Path Delay for Flip-Flops Using a Single Clock

Figure 3-4 shows how the tool determines the setup and hold constraints for a path that begins and ends on rising-edge-triggered flip-flops. The two flip-flops are triggered by the same clock. The clock period is 10 ns.

CLK

CLK

CLK

CLK

CLK

Setup

10 20 30

Figure 3-4 Single-Cycle Setup and Hold for Flip-Flops

The tool performs a setup check to verify that the data launched from FF1 at time=0 arrives at the D input of FF2 in time for the capture edge at time=10. If the data takes too long to arrive, it is reported as a setup violation.

Similarly, the tool performs a hold check to verify that the data launched from FF1 at time 0 does not get propagated so soon that it gets captured at FF2 at the clock edge at time 0. If the data arrives too soon, it is reported as a hold violation.

The setup and hold requirements determined by the tool for sequential elements take into account all relevant parameters such as the delay of the combinational logic elements in the path, the setup and hold requirements of the flip-flop elements as defined in the technology library, and the net delays between the flip-flops.

# Path Delay for Flip-Flops Using Different Clocks

The method of calculating path delays is more complicated when the launch and capture flip-flops belong to different clock domains.

Consider the circuit shown in Figure 3-5. The flip-flops at the beginning and end of the timing path are clocked by CLK1 and CLK2. The two clocks are declared by the <code>create\_clock</code> commands shown in the figure.

Figure 3-5 Setup Constraints for Flip-Flops With Different Clocks



create\_clock -period 10 -waveform {0 5} CLK1
create\_clock -period 25 -waveform {5 12.5} CLK2



By default, the tool assumes that the two clocks are synchronous to each other, with a fixed phase relationship. If this is not the case for the real circuit (for example, because the two clocks are never active at the same time or because they are asynchronous), then you need to declare this fact by using any of several methods. Otherwise, the tool spends time checking constraints and reporting violations that do not exist in the actual circuit.

## **Setup Analysis**

The tool looks at the relationship between the active clock edges over a full repeating cycle, equal to the least common multiple of the two clock periods. For each capture edge at the destination flip-flop, the tool assumes that the corresponding launch edge is the nearest source clock edge occurring before the capture edge.

In Figure 3-5, there are two capture edges in the period under consideration. For the capture edge at time=5, the nearest preceding launch edge is at time=0. The corresponding setup relationship is labeled Setup 1.

For the capture edge at time=30, the nearest preceding launch edge is at time=20. This setup relationship is labeled Setup 2. The source clock edge at time=30 occurs at the same time as the capture edge, not earlier, so it is not considered the corresponding launch edge.

Setup 1 allows less time between launch and capture, so it is the more restrictive constraint. It determines the maximum allowed delay for the path, which is 5 ns for this example.

# **Hold Analysis**

The hold relationships checked by the tool are based on the clock edges adjacent to those used to determine the setup relationships. To determine the most restrictive hold relationship, the tool considers all valid setup relationships, including both Setup 1 and Setup 2 in Figure 3-5.

For each setup relationship, the tool performs two different hold checks:

- The data launched by the setup launch edge must not be captured by the *previous* capture edge.
- The data launched by the *next* launch edge must not be captured by the setup capture edge.

Figure 3-6 shows the hold checks performed for the current example. First consider the setup relationship labeled Setup 2. The tool confirms that the data launched by the setup launch edge is not captured by the previous capture edge; this relationship is labeled Hold 2a. It also confirms that the data launched by the next clock edge at the source is not captured by the setup capture edge; this relationship is labeled Hold 2b.

Timing path FF2 FF1 Combinational D Q logic CLK1 CLK<sub>2</sub> Setup 1 Setup 2 launch edge launch edge CLK1<sub>FF1</sub> Hold 2b Hold 1a Hold 1b Hold 2a Setup 2 CLK2<sub>FF2</sub>

Figure 3-6 Hold Constraints for Flip-Flops With Different Clocks

The tool similarly checks the hold relationships relative to the clock edges of Setup 1, as indicated in the figure. The most restrictive hold check is the one where the capture edge occurs latest relative to the launch edge, which is Hold 2b in this example. Therefore, Hold 2b determines the minimum allowed delay for this path, 0 ns.

25

Setup 2 capture edge

30

35

40

45

50

# **Single-Cycle Path Analysis Examples**

The following examples further illustrate how the tool calculates the delay requirements for edge-triggered flip-flops in the absence of timing exceptions.

0

5

10

15

20

In Figure 3-7, CLK1 has a period of 20 ns and CLK2 has a period of 10 ns. The most restrictive setup relationship is the launch edge at time=0 to the capture edge at time=10. The most restrictive hold relationship is the launch edge at time=0 to the capture edge at time=0.

Figure 3-7 Delay Requirements With 20ns/10ns Clocks



create\_clock -period 20 -waveform {0 10} CLK1
create\_clock -period 10 -waveform {0 5} CLK2



In Figure 3-8, CLK1 has a period of 4 ns and CLK2 has a period of 3 ns. The most restrictive setup relationship is the launch edge at time=3 to the capture edge at time=4. The most restrictive hold relationship is the launch edge at time=7 to the capture edge at time=7, based on the setup relationship shown by the dashed-line arrow in the timing diagram.

Figure 3-8 Delay Requirements With 4ns/3ns Clocks



create\_clock -period 4 -waveform {3 4} CLK1
create\_clock -period 3 -waveform {1 2} CLK2



# **Timing Exceptions**

The Design Compiler and IC Compiler tools support the following types of timing exceptions:

- False paths. Use the set\_false\_path command to specify a logic path that exists in the design but should not be analyzed. Setting a false path removes the timing constraints on the path.
- Minimum and maximum path delay values. Use the set\_max\_delay and set\_min\_delay commands to override the default setup and hold constraints with specific maximum and minimum delay values.

• Multicycle paths. Use the set\_multicycle\_path command to specify the number of clock cycles required to propagate data from the start to the end of the path.

Each timing exception command can apply to a single path or to a group of related paths, such as all paths from one clock domain to another, or all paths that pass through a specified point in the design.

In a timing exception command, be sure to specify valid startpoints and endpoints. A startpoint must be a register clock pin or an input port. An endpoint must be a register data input pin or an output port.

To view a list of timing exceptions that have been applied to a design, use the report\_exceptions command. To restore the default timing constraints on a path, use the reset path command.

# **False Path Exceptions**

A false path is a logic path in the design that exists but should not be analyzed for timing. For example, a path can exist between two multiplexed logic blocks that are never selected at the same time, so that path is not valid for timing analysis.

For example, to declare a false path from pin FFB1/CP to pin FFB2/D:

Setting a false path is a point-to-point timing exception that removes all timing constraints from a path, which prevents errors from being reported but does not stop delay calculation. This is different from using the <code>set\_disable\_timing</code> command, which disables timing analysis entirely for a specified pin, cell, or port. If all paths through a pin are false, using <code>set\_disable\_timing</code> [<code>get\_pins pin\_name</code>] is more efficient than using <code>set\_false\_path -through</code> [<code>get\_pins pin\_name</code>].

Another example of a false path is a path between flip-flops belonging to two clock domains that are asynchronous with respect to each other. To declare all paths between two clock domains to be false, you can use a set of two commands such as the following:

For efficiency, be sure to specify each clock by its clock name, not by the pin name; use get\_clocks rather than get\_pins.

An alternative is to use the <code>set\_clock\_groups</code> command to exclude paths from consideration that are launched by one clock and captured by another.

In Figure 3-9, the adder is shared between the multiplexed inputs a, b, c, and d. The logic of this design prevents the path from port "a" to port "c\_d" from being enabled, so it is a false path.

Figure 3-9 False Path Example



To declare this as a false path and thereby prevent the tool from analyzing this path timing, you could use:

```
prompt> set_false_path -from [get_ports a] -to [get_ports c_d]
or, more generally for this example,
prompt> set_false_path -from [get_ports {a b}] -to [get_ports c_d]
prompt> set_false_path -from [get_ports {c d}] -to [get_ports a_b]
```

The tool has the ability to detect the presence of certain types of false paths in the design when you use case analysis. To detect false paths, use the <code>report\_timing</code> command with the <code>-justify</code> option.

# **Maximum and Minimum Path Delay Exceptions**

By default, the tool calculates the maximum and minimum allowable path delays by considering the launch and capture clock edge times. To override the default maximum or minimum time with your own specific time value, use the <code>set\_max\_delay</code> or <code>set\_min\_delay</code> command. For example, to set the maximum path delay between registers REGA and REGB to 12, use the following command:

With this timing exception, the tool ignores the clock relationships. A path delay between these registers that exceeds 12.0 time units minus the setup requirement of the endpoint register is reported as a timing violation.

Similarly, to set the minimum path delay between registers REGA and REGB to 2, use the following command:

Again, the tool ignores the clock relationships. A path delay between these registers that is less than 2 time units plus the hold requirement of the endpoint register is reported as a timing violation.

# **Multicycle Path Exceptions**

The set\_multicycle\_path command specifies the number of clock cycles required to propagate data from the start of a path to the end of the path. The tool calculates the setup or hold constraint according to the specified number of cycles.

For example, consider the circuit shown in Figure 3-10. The path from FF4 to FF5 is designed to take two clock cycles rather than one. However, by default, the tool assumes single-cycle timing for all paths. Therefore, you need to specify a timing exception for this path.

CLK

FF1

FF2

FF3

CLK

FF4

FF5

FF5

Figure 3-10 Multicycle Path Example

One timing exception method is to specify an explicit maximum delay value with the set\_max\_delay command. However, you might want to use set\_multicycle\_path instead because the maximum delay value is automatically adjusted when you change the clock period.

To set the multicycle path for the design shown in Figure 3-10, you can use the following command:

```
prompt> set_multicycle_path -setup 2 \
     -from [get_cells FF4] -to [get_cells FF5]
```

This command specifies that the path takes two clock cycles rather than one, establishing the new setup relationship shown in Figure 3-11. The second capture edge following the launch edge becomes the applicable edge for the end of the path.

Figure 3-11 Multicycle Path Setup



Changing the setup relationship implicitly changes the hold relationship as well because all hold relationships are based on the valid setup relationships. The tool verifies that the data launched by the setup launch edge is not captured by the previous capture edge. The new hold relationship is shown in Figure 3-12.

Figure 3-12 Multicycle Path Hold Based on New Setup



prompt> set\_multicycle\_path -setup 2 \
 -from [get\_cells FF4] -to [get\_cells FF5]

The hold relationship shown in Figure 3-12 is probably not the correct relationship for the design. If FF4 does not need to hold the data beyond the first clock edge, you need to specify a multicycle hold timing exception.

Although you could use the set\_min\_delay command to specify a particular hold time, it is better to use another set\_multicycle\_path command to move the capture edge for the hold relationship backward by one clock cycle. For example,

Figure 3-13 shows the setup and hold relationships set correctly with two set\_multicycle\_path commands. The second set\_multicycle\_path command moves the capture edge of the hold relationship backward by one clock cycle, from the dashed-line arrow to the solid-line arrow.

Figure 3-13 Multicycle Path Hold Set Correctly



The tool interprets the <code>-setup</code> and <code>-hold</code> values in the <code>set\_multicycle\_path</code> command differently. The integer value for the <code>-setup</code> argument specifies the number of clock cycles for the multicycle path. In the absence of a timing exception, the default is 1. The integer value for the <code>-hold</code> argument specifies the number of clock cycles to move the capture edge backward with respect to the default position, relative to the valid setup relationship; the default setting is 0.

The example shown in Figure 3-14 further demonstrates the setting of multicycle paths. In the absence of timing exceptions, the setup relationship is from time=0 to time=10, as indicated by the dashed-line arrow, and the hold relationship is from time=0 to time=0.

Figure 3-14 Multicycle Path Taking Five Clock Cycles



prompt> create\_clock -period 10 -waveform {0 5} CLK1



With set\_multicycle\_path -setup 5, the setup relationship spans five clock cycles rather than one, from time=0 to time=50, as shown by the long solid-line arrow. This implicitly changes the hold relationship to the prior capture edge at time=40, as shown by the long dashed-line arrow.

To move the capture edge for the hold relationship back to time=0, you need to use set\_multicycle\_path -hold 4 to move the capture edge back by four clock cycles.

To summarize, the tool determines the number of hold cycles as follows:

 $(hold\ cycles) = (setup\ option\ value) - 1 - (hold\ option\ value)$ 

By default, hold cycles = 1 - 1 - 0 = 0. For Figure 3-13, hold cycles = 2 - 1 - 1 = 0. For Figure 3-14, hold cycles = 5 - 1 - 4 = 0.

You can optionally specify that the multicycle path exception apply only to rising edges or only with falling edges at the path endpoint. If the startpoint and endpoint are clocked by different clocks, you can specify which of the two clocks is considered for adjusting the number of clock cycles for the path.

# **Specifying Exceptions Efficiently**

In many cases, you can specify the exception paths many different ways. Choosing an efficient method can reduce the runtime. For example, consider the circuit shown in Figure 3-15. The three 16-bit registers are clocked by three different clocks. Each register represents 16 flip-flops. Register REG2 is only used for test purposes, so all paths from REG2 to REG3 are false paths during normal operation of the circuit.

Figure 3-15 Multiplexed Register Paths



To prevent analysis of timing from REG2 to REG3, you can use any of the following methods:

- Use case analysis to consider the case when the test enable signal is 0. (See "Case Analysis" in Chapter 5)
- Set an exclusive relationship between the CLK1 and CLK2 clock domains. See "Mode Analysis" on page 5-23.
- Declare the paths between clock domains CLK2 and CLK3 to be false.

This method is an efficient way to specify the false paths because the tool only needs to keep track of the specified clock domains. It does not have to keep track of exceptions on registers, pins, nets, and so on.

Declare the 16 individual paths from REG2 to REG3 to be false.

This method is less efficient because the tool must keep track of timing exceptions for 16 different paths.

Declare all paths from REG2 to REG3 to be false.

This method is even less efficient because the tool must keep track of paths from each clock pin of REG2 to each data pin of REG3, a total of 256 paths.

Declare all paths from REG2 to be false.

```
prompt> set_false_path -from [get_pins REG2[*]/CP]
```

This method is similar to the previous one. The tool must keep track of all paths originating from each clock pin of REG2, a total of 256 paths.

In summary, look at the root cause that is making the exceptions necessary and find the simplest way to control the timing analysis for the affected paths. Before using false paths, consider using case analysis (set\_case\_analysis), declaring an exclusive relationship between clocks (set\_clock\_groups), or disabling analysis of part of the design (set\_disable\_timing). These alternatives can be more efficient than using the set\_false\_path command. If you must set false paths, avoid specifying a large number of paths using the -through argument, by using wildcards, or by listing the paths one at a time.

# **Exception Order of Precedence**

If different timing exception commands are in conflict for a particular path, the exception used for that path depends on the exception types or the path specification methods used in the conflicting commands. A set of rules establishes the order of priority for different exception-setting situations.

The tool applies the exception precedence rules independently on each path, not each command. For example, suppose that you use the following commands:

```
prompt> set_max_delay -from A 5.1
prompt> set_false_path -to B
```

The set\_false\_path command has priority over the set\_max\_delay command, so any paths that begin at A and end at B are false paths. However, the set\_max\_delay command still applies to paths that begin at A but do not end at B.

# **Exception Type Priority**

The following pairs of timing exception types are not considered to be in conflict, so both settings can be valid for a path:

- Two set\_false\_path settings
- set\_min\_delay and set\_max\_delay settings
- set multicycle path -setup and -hold settings

In case of conflicting exceptions for a particular path, the timing exception types have the following order of priority, from highest to lowest:

```
    set_false_path
    set_max_delay and set_min_delay
    set multicycle path
```

For example, if you declare a path to be false and also set its maximum delay to some value, the false path declaration has priority. The maximum delay setting is ignored.

# **Path Specification Priority**

If you apply the same type of timing exception using commands with different path specifications, the more specific command has priority over the more general one. Exceptions of any type on more specific objects, such as pins or ports, take precedence over exceptions applied to more general objects, such as clocks. For example,

```
prompt> set_max_delay 12 -from [get_clocks CLK1]
prompt> set_max_delay 15 -from [get_clocks CLK1] -to [get_clocks CLK2]
```

The first command sets the maximum delay of all paths starting from CLK1. However, the second command is more specific, so it overrides the first command for paths starting at CLK1 and ending at CLK2.

The various -from/-to path specification methods have the following order of priority, from highest to lowest:

```
1. -from pin, -rise from pin, -fall from pin
```

```
2. -to pin, -rise to pin, -fall to pin
```

- 3. -through, -rise\_through, -fall\_through
- 4. -from clock, -rise from clock, -fall from clock
- 5. -to clock, -rise\_to clock, -fall\_to clock

Use the preceding list to determine which of two conflicting timing exception commands has priority, for example, two set\_max\_delay commands. Starting from the top of the list:

- 1. A command containing -from pin, -rise\_from pin, or -fall\_from pin has priority over a command that does not contain -from pin, -rise\_from pin, or -fall\_from pin.
- 2. A command containing -to pin, -rise\_to pin, or -fall\_to pin has priority over a command that does not contain -to pin, -rise\_to pin, or -fall\_to pin.
- ... and so on down the list until the priority is resolved.

Here are some possible path specification combinations, listed in order of priority from highest to lowest, according to the preceding priority rules:

```
1. -from pin -to pin
```

- 2. -from pin -to clock
- 3. -from pin
- 4. -from clock -to pin
- **5**. -to pin
- 6. -from clock -to clock
- $7. from \ clock$
- 8. -to clock

# **Reporting Exceptions**

The report\_timing\_requirements command generates a report on timing exceptions that have been set. For example,

# prompt> report\_timing\_requirements ... Description Setup Hold TIMING EXCEPTION FALSE FALSE -from SYS\_CLK\ -to PCI\_CLK TIMING EXCEPTION FALSE FALSE -from PCI\_CLK\ -from PCI\_CLK\ -to SYS\_CLK\

You can reduce the scope of the report by using the path specification arguments <code>-from</code>, <code>-to</code>, <code>-through</code>, <code>-rise\_from</code>, <code>-fall\_to</code>, and so on, to match the path specifiers used when the original exceptions were created.

Exception-setting commands are sometimes ignored for a number of reasons. For example, if a false path is specified from port A to port Z1, but no such path exists between those ports, the exception setting is ignored. To get a report on ignored exceptions, use the - ignored option of the report\_timing\_requirements command. For example,

| prompt> report_t                 | rt_timing_requirements -ignored  Setup Hold |       |       |
|----------------------------------|---------------------------------------------|-------|-------|
| Description                      |                                             | Setup | Hold  |
| NONEXISTENT PATH -from -to       | SYS_2x_CLK\ PCI_CLK                         | FALSE | FALSE |
| NONEXISTENT PATH<br>-from<br>-to | SDRAM_CLK\ PCI_CLK                          | FALSE | FALSE |
| • • •                            |                                             |       |       |

### Note:

In PrimeTime, the command to report timing exceptions is report\_exceptions rather than report\_timing\_requirements.

# **Removing Exceptions**

To remove a timing exception previously set with set\_false\_path, set\_max\_delay, set\_min\_delay, or set\_multicycle\_path, use the reset\_path command.

You control the scope of exception removal in the reset\_path command by specifying -from, -to, -through, -rise\_from, -fall\_to, and so on. The path specification and object must match the original path specification and object used to set the exception. Otherwise, the reset\_path command has no effect. For example,

In each of these two examples, the object in the reset\_path command does not match the original object, so the paths are not reset, even though they might have exceptions applied.

You can use the <code>-reset\_path</code> option in an exception-setting command to reset all of the exceptions set on a path before the new exception is applied. For example,

```
prompt> set_false_path -through [get_pins d/Z] -reset_path
```

This example first resets all timing exceptions previously applied to the paths through the specified point, then applies the false path exception to these paths.

The reset design command removes all exceptions from the design.

### **Data-to-Data Checks**

The tool can perform setup and hold checking between two data signals, neither of which is defined to be a clock, at any two pins in the design. A timing constraint between two data (nonclock) signals is called a nonsequential constraint. This feature can be useful for checking the following types of timing constraints:

- Constraints on handshaking interface logic
- Constraints on asynchronous or self-timed circuit interfaces
- Constraints on signals with unusual clock waveforms that cannot be easily specified with the create\_clock command
- Constraints on skew between bus lines
- Recovery and removal constraints between asynchronous preset and clear input pins

You can define such checks by using the <code>set\_data\_check</code> command, or you can define them for a library cell by setting nonsequential constraints for the cell in Library Compiler. You should use data checks only in situations such as those described above. Data checks should not be considered a replacement for ordinary sequential checking.

Figure 3-16 shows a simple example of a cell that has a nonsequential constraint. The cell has two data inputs, D1 and D2. The rising edge of D2 is the active edge that might be used to latch data at D1. Pin D1 is called the constrained pin and pin D2 is called the related pin. In a sequential setup or hold check, pin D2 would be considered the clock pin. However, for any of a number of reasons, it might be desirable to consider the signal at D2 a data signal, and not define it to be a clock.

Figure 3-16 Simple Data Check Example



In this example, the signal at D1 must be stable for a certain setup time before the active edge. It must also be stable for a certain hold time after the active edge. If these nonsequential constraints are not already defined for the library cell, you can define them in the tool with the set\_data\_check command.

# **Specifying Data-to-Data Checks**

You use the set\_data\_check command to specify that data-to-data checks be performed between two data pins. This is the command syntax:

```
set_data_check
{-from from_object | -rise_from from_object | -fall_from from_object}
{-to to_object | -rise_to to_object | -fall_to to_object}
[-setup | -hold]
[-clock clock_object]
[check_value]
```

Use options to the command as follows:

• To specify a pin or port in the current design as the related pin, use the -from, -rise from, or -fall from option.

- To specify a pin or port in the current design as the constrained pin, use the -to, -rise\_to, or -fall\_to option.
- To specify that the data check value be for setup only or hold only, use the -setup option or -hold option. Otherwise, the value applies to both setup and hold.
- To specify the name of a single clock that launches the signal for the related pin, use the -clock option.

### Example 1

In Figure 3-17, the signal at D1 must be stable for a certain setup time before the active edge. It must also be stable for a certain hold time after the active edge.

Figure 3-17 Data Check on Rising Edge



To define these data-to-data checks, use commands similar to the following:

```
prompt> set_data_check -rise_from D2 -to D1 -setup 3.5
prompt> set_data_check -rise_from D2 -to D1 -hold 6.0
```

### Example 2

In Figure 3-18, the data checks apply to both rising and falling edges on the related pin. Use the -from option instead of the -rise\_from or -fall\_from option.

Figure 3-18 Data Checks on Rising and Falling Edges



To define these data checks, use the following commands:

```
prompt> set_data_check -from D2 -to D1 -setup 3.5
prompt> set_data_check -from D2 -to D1 -hold 6.0
```

### Example 3

You can define a no-change data check by specifying only a setup check from the rising edge and a hold check from the falling edge:

```
prompt> set_data_check -rise_from D2 -to D1 -setup 3.5
prompt> set_data_check -fall_from D2 -to D1 -hold 3.0
```

The tool interprets this as a no-change check on a positive-going pulse. The resulting timing check is illustrated in Figure 3-19.

Figure 3-19 No-Change Data Check



To remove data checks set with the set\_data\_check command, use the remove\_data\_check command.

# **Generating Timing Reports for Data Checks**

Data checks are nonsequential, so they do not break timing paths. For example, in Figure 3-20, the data check between D1 and D2 does not interrupt the timing paths shown by the dashed-line arrows. If you were to define the signal at D2 to be a clock, the check would be sequential and the paths would be terminated at D1.

ff1 Combinational D1 Data check dchk

Figure 3-20 Timing Paths Not Broken by Data Checks

You can specify a data check pin as a path endpoint for the report\_timing command. In that case, the tool reports the data checks that apply to the pin. For example, for the circuit shown in Figure 3-20, report\_timing -to dchk/D1 generates a data check report, whereas report\_timing -through dchk/D1 generates a timing report on ordinary paths that pass through the specified pin and paths that end at the data check pin.

### **Data Checks and Clock Domains**

In a data check, signals arriving at a constrained pin or related pin can come from different clock domains. The tool checks the signal paths separately and puts them into different clock groups, just like in ordinary sequential checks.

If the related pin has signals from multiple clock domains, you might want to specify which clock domain to analyze at that pin for the data check. To do this, either use the <code>-clock</code> <code>clock\_name</code> option of the <code>set\_data\_check</code> command, or disable all clocks other than the clock of interest.

# **Library-Based Data Checks**

You can use the timing\_enable\_non\_sequential\_checks variable to specify that the tool perform data checking for any cell that has nonsequential timing constraints defined in the library cell, as long as the signal at the related pin is not defined to be a clock. If the signal is defined to be a clock, the tool ignores the library-defined nonsequential timing constraints. The variable is set to false by default.

### Note:

This behavior is different from that of PrimeTime, which always honors nonsequential arc checks.

In Library Compiler, you define nonsequential constraints on a cell by specifying a related pin and by assigning the following timing\_type attributes to the constrained pin:

```
non_seq_setup_rising
non_seq_setup_falling
non_seq_hold_rising
non_seq_hold_falling
```

For more information on defining nonsequential constraints in the library, see the Library Compiler documentation.

Defining nonsequential constraints in the library cell results in a more accurate analysis than using the <code>set\_data\_check</code> command because the setup and hold times can be made sensitive to the slew of the constrained pin and the related pin. The <code>set\_data\_check</code> command is not sensitive to slew.

To specify which clock domain to use at the related pin for data checks defined in library cells, you can use the <code>-clock clock\_name</code> option of the <code>set\_data\_check</code> command.

The remove data check command does not remove data checks defined in library cells.

4

# **Operating Conditions**

The technology library can specify multiple sets of chip operating conditions (process, voltage, and temperature). You use the set\_operating\_conditions command to choose the operating conditions to use for timing analysis and optimization. In the best-case/worst-case or on-chip variation analysis mode, the tool simultaneously checks the circuit for the two extreme operating conditions, minimum and maximum.

Operating conditions are described in the following sections:

- Operating Condition Definitions
- Setting Operating Conditions
- Operating Condition Modes
- Minimum and Maximum Delay Calculations
- Using Two Libraries for Min-Max Analysis
- Setting Derating Factors
- Voltage and Temperature Scaling Between Libraries
- Clock Reconvergence Pessimism Removal

# **Operating Condition Definitions**

The operating conditions of a design include the process, voltage, and temperature parameters under which the chip is intended to operate. The Design Compiler and IC Compiler tools analyze and optimize the design under the conditions you specify.

To see the libraries and operating conditions being used in the current design, use the report\_design command. To get a list of the operating conditions available in a particular library and to view their characteristics, use either the report\_operating\_conditions -library lib\_name command or the report\_lib -operating\_condition lib\_name command.

Operating conditions are usually specified in the technology library of the design. Multiple sets of conditions can be specified, such as worst, typical, and best; and commercial, industrial, and military specifications.

The following excerpt from a technology library in Liberty format defines three operating conditions called BEST, TYPICAL, and WORST:

```
library (my_library) {
  operating_conditions(BEST) {
    process : 1.1;
    temperature : 11.0;
    voltage : 4.6;
    tree_type : "best_case_tree";
  }
  operating_conditions(TYPICAL) {
    process : 1.3;
    temperature : 31.0;
    voltage : 4.6;
    tree_type : "balanced_tree";
    }
  operating_conditions(WORST) {
    process : 1.7;
    temperature : 55.0;
    voltage : 4.2;
    tree_type : "worst_case_tree";
    }
  ...
```

For more information about defining operating conditions in libraries, see the *Library Compiler Modeling Timing, Signal Integrity, and Power in Technology Libraries User Guide*, available on SolvNet.

You can create your own operating conditions in Design Compiler or IC Compiler with the create\_operating\_conditions command. For example,

This example creates a new operating condition called WC\_CUSTOM, which is associated with the existing technology library called tech1. The process, temperature, and voltage values are 1.2, 30.0, and 2.8 respectively. The tree type is set to worst\_case\_tree.

The tree type is the type model used for estimating the distribution of net resistance and capacitance for each net. The -tree\_type option can be set to best\_case\_tree, balanced\_tree, or worst\_case\_tree. The tree type models are shown in Figure 4-1.

Figure 4-1 RC Interconnect Topologies for Fanout of N



In the best-case tree, the receiver being analyzed is physically close to the driver compared to the other loads, so all the net resistance is assumed to be beyond the capacitive loads, resulting in a larger drive current and the smallest possible delay.

In the balanced tree, all the receivers are the same distance from the driver, so the net resistance and capacitance are evenly distributed between multiple loads, resulting in average delay.

In the worst-case tree, the receiver being analyzed is physically far from the driver compared to the other loads, so all the net resistance is assumed to be between the driver and the capacitive loads, resulting in a smaller drive current and the largest possible delay.

# **Setting Operating Conditions**

In Design Compiler or IC Compiler, the set\_operating\_conditions command specifies
the operating conditions for analysis and optimization, so that the tool can use the
appropriate set of parameter values in the technology library. This is the syntax of the
command:

```
set_operating_conditions
  [-analysis_type bc_wc | on_chip_variation]
  [-min min_condition] [-max max_condition]
  [-min_library min_lib] [-max_library max_lib]
  [-min_phys min_proc] [-max_phys max_proc]
  [-library library_name]
  [-object_list objects]
  [condition_name]
```

If you do not use the <code>-analysis\_type</code> option, the tool performs analysis at a single operating condition. In that case, you specify only a single condition name. For example,

```
prompt> set_operating_conditions TYPICAL
```

The <code>-analysis\_type</code> option selects a mode in which the minimum and maximum conditions are analyzed at the same time. You specify the min-max analysis type, either <code>bc\_wc</code> (best-case/worst-case) or <code>on\_chip\_variation</code>. In the best-case/worst-case mode, the tool uses the maximum operating condition for setup checks and the minimum operating condition for hold checks. In the on-chip variation mode, the tool uses the maximum operating condition for all maximum path delays and the minimum operating condition for all minimum path delays. For example, for a setup check, the on-chip variation mode uses the maximum operating condition for the data path and the minimum operating condition for the capture clock path.

In the best-case/worst-case or on-chip variation mode, use the  $-\min$  and  $-\max$  options to specify the minimum and maximum operating conditions. If the same condition name can be found in multiple libraries, you can use the  $-\min_{\text{library}}$  and  $-\max_{\text{library}}$  options to

specify the libraries from which to obtain the operating conditions. If these operating conditions come from the same library, you can use the <code>-library</code> option to specify the library name. Use can the <code>-min\_phys</code> and <code>-max\_phys</code> options to specify the names of the process resources (technology files) containing the interconnect resistance and capacitance values to be used for minimum and maximum analysis.

The -object\_list option lets you apply the operating conditions to specified cells or ports in multivoltage applications. By default, the whole design is affected.

To remove operating conditions that have been previously set, use the remove\_operating\_conditions command.

# **Operating Condition Modes**

The Design Compiler and IC Compiler tools offer three modes with respect to operating conditions: single, best-case/worst-case, and on-chip variation:

- In the single operating condition mode, the tool uses a single set of delay parameters for the whole circuit, based on one set of process, temperature, and voltage conditions.
- In the best-case/worst-case mode, the tool simultaneously checks the circuit for the two extreme operating conditions, minimum and maximum. For setup checks, it uses maximum delays for all paths. For hold checks, it uses minimum delays for all paths.
- In the on-chip variation mode, the tool performs a conservative analysis that allows both
  minimum and maximum delays to apply to different paths at the same time. For a setup
  check, it uses maximum delays for the launch clock path and data path, and minimum
  delays for the capture clock path. For a hold check, it does the opposite. This mode
  models the effects of variation in operating conditions across the chip.

Table 4-1 and Table 4-2 show the clock arrival times, delays, operating conditions, and derating used for setup checks and for hold checks under each of the operating condition modes.

Table 4-1 Timing Parameters Used for Setup Checks

| Analysis mode                 | Launch clock path                                                                  | Data path                                                | Capture clock path                                                                   |
|-------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------|
| Single operating condition    | Late clock, maximum delay in clock path, single operating cond. (no derating)      | Maximum delay, single operating cond. (no derating)      | Early clock, minimum delay in clock path, single operating cond. (no derating)       |
| Best-case/worst-<br>case mode | Late clock, maximum delay in clock path, late derating, worst-case operating cond. | Maximum delay, late derating, worst-case operating cond. | Early clock, minimum delay in clock path, early derating, worst-case operating cond. |
| On-chip variation mode        | Late clock, maximum delay in clock path, late derating, worst-case operating cond. | Maximum delay, late derating, worst-case operating cond. | Early clock, minimum delay in clock path, early derating, best-case operating cond.  |

Table 4-2 Timing Parameters Used for Hold Checks

| Analysis mode                 | Launch clock path                                                                   | Data path                                                | Capture clock path                                                                 |
|-------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------|
| Single operating condition    | Early clock, minimum delay in clock path, single operating cond. (no derating)      | Minimum delay, single operating cond. (no derating)      | Late clock, maximum delay in clock path, single operating cond. (no derating)      |
| Best-case/worst-<br>case mode | Early clock, minimum delay in clock path, early derating, best-case operating cond. | Minimum delay, early derating, best-case operating cond. | Late clock, maximum delay in clock path, late derating, best-case operating cond.  |
| On-chip variation mode        | Early clock, minimum delay in clock path, early derating, best-case operating cond. | Minimum delay, early derating, best-case operating cond. | Late clock, maximum delay in clock path, late derating, worst-case operating cond. |

# **Minimum and Maximum Delay Calculations**

A best-case/worst-case or on-chip variation analysis considers the minimum and maximum values specified for the following design parameters:

- · Input and output external delays
- Delays annotated from Standard Delay Format (SDF)
- Port wire load models
- Port fanout number
- Net capacitance
- Net resistance
- Net wire load model
- Clock latency
- Clock transition time
- Input port driving cell

For example, to calculate a maximum delay, the tool uses the longest path, worst-case operating conditions, latest-arriving clock edge, maximum cell delays, longest transition times, and so on.

You can do best-case/worst-case or on-chip variation analysis using a single library with minimum and maximum operating conditions specified, or two libraries, one for the best-case conditions and one for the worst-case conditions. For more information, see "Using Two Libraries for Min-Max Analysis" on page 4-12.

# Min-Max Cell and Net Delay Values

Each timing arc in the design can have a minimum and a maximum delay to account for variations in operating conditions. You can specify these values in the following ways:

- Annotate delays from one or two SDF files
- Have the tool calculate the delay

To annotate delays from one or two SDF files, do one of the following:

- Use min and max from the SDF triplet.
- · Use two SDF files.

To have the tool calculate the delay, do one of the following:

- Use a single operating condition with timing derating factors to model variation.
- Use two operating conditions (best case and worst case) to model the possible on-chip variation.

Table 4-3 summarizes the usage of minimum and maximum delays from SDF triplet data.

Table 4-3 Min-Max Delays From SDF Triplet Data

| Analysis<br>mode           | Delay based on operating conditions                                                                                            | One SDF<br>file                                                                                        | Two SDF files                                                                                                             |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| Single operating condition | Setup - max data at operating condition - min capture clock at operating cond.                                                 | Setup<br>- (a:b: <b>c</b> )<br>- (a:b: <b>c</b> )                                                      |                                                                                                                           |
|                            | Hold - min data at operating condition - max capture clock at operating cond.                                                  | Hold<br>- (a:b: <b>c</b> )<br>- (a:b: <b>c</b> )                                                       |                                                                                                                           |
| Best case-<br>worst case   | Setup - max data at worst case - min capture clock at worst case Hold - min data at best case - max capture clock at best case | Setup<br>- (a:b: <b>c</b> )<br>- (a:b: <b>c</b> )<br>Hold<br>- ( <b>a</b> :b:c)<br>- ( <b>a</b> :b:c). | Setup<br>SDF1 - (a:b: <b>c</b> )<br>SDF2 - (a:b: <b>c</b> )<br>Hold<br>SDF1 - ( <b>a</b> :b:c)<br>SDF2 - ( <b>a</b> :b:c) |
| On-chip variation          | Setup - max data at worst case - min capture clock at best case                                                                | Setup<br>- (a:b: <b>c</b> )<br>- ( <b>a</b> :b:c)                                                      | Setup<br>SDF1 - (a:b: <i>c</i> )<br>SDF2 - ( <b>a</b> :b:c)                                                               |
|                            | Hold - min data best case - max capture clock at worst case                                                                    | Hold<br>- ( <b>a</b> :b:c)<br>- (a:b: <b>c</b> )                                                       | Hold<br>SDF1 - ( <b>a</b> :b:c)<br>SDF2 - (a:b: <b>c</b> )                                                                |

The triplet displayed in **bold italic** is the triplet that the tool uses.

# **Setup and Hold Checks**

This section provides examples of how setup and hold timing checks are done for a single operating condition, for simultaneous best-case/worst-case operating conditions, and for on-chip variation.

# Path Delay Tracing for Setup and Hold Checks

Figure 4-2 shows how setup and hold checks are done.

Figure 4-2 Design Example Showing Setup and Hold Checks



- The setup timing check from pin DL2/ck to DL2/d considers
  - Maximum delay for clock\_path1
  - Maximum delay for data path (data\_path\_max)
  - Minimum delay for clock\_path2
- The hold timing check from pin DL2/ck to DL2/d considers
  - Minimum delay for clock\_path1
  - Minimum delay for data path (data\_path\_min)
  - Maximum delay for clock\_path2

The data\_path\_min and data\_path\_max values can be different due to multiple topological paths in the combinational logic that connects DL1/q to DL2/d.

# **Setup Timing Check for Worst-Case Conditions**

Figure 4-3 shows how cell delays are computed for worst-case conditions. To simplify the example, the net delays are ignored.

Figure 4-3 Setup Check Using Worst-Case Conditions



The tool checks for a setup violation as follows:

clockpath1 +datapathmax - clockpath2 +setup ≤clockperiod

In the equation,

clockpath1 = 0.8 + 0.6 = 1.4datapathmax = 3.8clockpath2 = 0.8 + 0.65 = 1.45setup = 0.2

The clock period must be at least 1.4 + 3.8 - 1.45 + 0.2 = 3.95.

# **Hold Timing Check for Best-Case Conditions**

Figure 4-4 shows how cell delays are computed for best-case conditions. Note that the cell delays are different from the delays in Figure 4-3.

Figure 4-4 Hold Check Using Best-Case Conditions



The tool checks for a hold violation as follows:

clockpath1+datapathmin-clockpath2 - hold ≥ 0

In the equation,

clockpath1 = 0.5 + 0.3 = 0.8datapathmin = 1.6clockpath2 = 0.5 + 0.35 = 0.85hold = 0.1

No hold violation exists because 0.8 + 1.6 - 0.85 - 0.1 = 1.45, which is greater than 0.

#### Simultaneous Best-Case/Worst-Case Conditions

In best-case/worst-case mode, the tool uses worst-case conditions for setup checks and best-case conditions for hold checks. The timing reports for setup and hold checks are the same as for Figure 4-3 and Figure 4-4.

### **Path Tracing in On-Chip Variation Mode**

In Figure 4-5, each delay of a cell or a net has an uncertainty because of on-chip variation. For example, you can specify that on-chip variation can be between 80 percent and 100 percent of the nominal delays for worst-case conditions. Figure 4-5 shows the resulting delays.

Figure 4-5 On-Chip Variation for Worst-Case Conditions



In this mode, for a given path, the maximum delay is computed at 100 percent of worst case, and the minimum delay is computed at 80 percent of worst case. The tool checks for a setup violation as follows:

clockpath1+datapathmax-clockpath2+setup≤clockperiod

In the expression,

clockpath1 = 0.80 + 0.60 = 1.40 (at 100% of worst case)

```
datapath_max = 3.80 (at 100\% of worst case) clockpath2 = 0.64 + 0.52 = 1.16 (at 80\% of worst case) setup = 0.2
```

The clock period must be at least 1.40 + 3.80 - 1.16 + 0.2 = 4.24

On-chip variation affects the clock latencies; therefore, you only need it when you are using propagated clock latency. If you specify ideal clock latency, you can have the tool consider on-chip variation by increasing the clock uncertainty values with the set\_clock\_uncertainty command.

### **Using Two Libraries for Min-Max Analysis**

The set\_min\_library command directs the tool to use two technology libraries simultaneously for minimum-delay and maximum-delay analysis. For example, you can choose two libraries that have the following characteristics:

- Best-case and worst-case operating conditions
- · Optimistic and pessimistic wire load models
- Minimum and maximum timing delays

To perform an analysis of this type, use the <code>set\_min\_library</code> command to create a minimum/maximum association between two libraries. You specify one library to be used for maximum delay analysis and another to be used for minimum delay analysis. Only the maximum library should be present in the link path.

When you use the <code>set\_min\_library</code> command, the tool first checks the library cell in the maximum library, and then looks in the minimum library to see if a match exists. If a library cell with the same name, the same pins, and the same timing arcs exists in the minimum library, the tool uses that timing information for minimum analysis. Otherwise, it uses the information in the maximum library. For more information, see the <code>set\_min\_library</code> man page.

### **Setting Derating Factors**

You can have the tool adjust minimum delays and maximum delays by specified factors to model the effects of varying operating conditions. This adjustment of calculated delays is called derating. Derating affects the delay and slack values calculated for the design.

The set\_timing\_derate command specifies the adjustment factors and the scope of the design to be affected by derating. For example,

```
prompt> set_timing_derate -early -cell_delay 0.9
prompt> set timing derate -late -cell delay 1.2
```

The first of these two commands causes all early (shortest-path) delays to be decreased by 10%, such as the capture clock path in a setup check. The second command causes all late (longest-path) delays to be increased by 20%, such as the launch clock path and the data path in a setup check. These changes result in a more conservative analysis than leaving delays at their original calculated values.

The <code>-early</code> or <code>-late</code> option specifies whether the shortest-path or longest-path delays are affected by the derating factor. Early path delays include the capture clock path for a setup check, and the launch clock path and data path for a hold check. Late path delays include the launch clock path and data path for a setup check, and the capture clock path for a hold check.

The fixed-point value in the command specifies the derating factor applied to the delays. Use a value of less than 1.0 to reduce the delay of any given path or cell check. Similarly, use a derating factor greater than 1.0 to increase the delay of any given path or cell check. Typically, derating factors less than 1.0 are used for early (shortest-path) delays and greater than 1.0 for late (longest-path) delays. This approach results in a more conservative analysis.

The last derating value to be set overrides any previously set values. To reset the derating factor globally to 1.0, use the reset\_timing\_derate command.

Delays are adjusted according to the following formula:

```
delay new = old delay + ((derate factor - 1.0) * abs(old delay))
```

When the delay is a positive value (the usual case), this equation is reduced to:

```
delay_new = old_delay * derate_factor
```

For negative delay, the delay adjustment equation is reduced to:

```
delay_new = old_delay * ( 2.0 - derate_factor )
```

Delays can be negative in some unusual situations. For example, if the input transition is slow and the output transition is fast for a cell, the time at which the input signal reaches the 50% trip point can be later than the time at which the output signal reaches the 50% trip point. The resulting delay from input to output is negative. A similar situation can occur for a net because of a change in delay caused by crosstalk. In addition, the library hold time requirement for a sequential cell can be negative.

The <code>-rise</code> or <code>-fall</code> option specifies whether rise delays or fall delays are affected by derating. If neither option is used, both types of delays are affected. The <code>-clock</code> or <code>-data</code> option specifies whether clock paths or data paths are affected by derating. If neither option is used, both types of paths are affected. A clock path is a path from a clock source to the clock input pin of a launch or capture register. A data path is a path starting from an input port or from the data output of a launch register, and ending at an output port or at the data input of a capture register.

The <code>-net\_delay</code>, <code>-cell\_delay</code>, and <code>-cell\_check</code> options let you specify the functional scope of the design to be affected by derating. The <code>-net\_delay</code> option derates the delay from a net driver to a net load. The <code>-cell\_delay</code> option derates the delay from a cell input to a cell output. The <code>-cell\_check</code> option derates cell timing checks, which are the cell hold and removal times for early derating or the cell setup and recovery times for late derating. Cell checks are setup and hold timing requirements for cells, not delays. If you do not use any of these options, the derating factor applies to both net delays and cell delays, but not cell timing checks.

If you want only some cells or nets to be affected by derating, you can list them in the command. The list can include library cells, hierarchical cells, leaf-level cells, and nets. In the absence of a list, the whole design is affected.

If you set a derating factor on a net that crosses a hierarchical boundary, the derating affects the whole net, not just the part of the net listed in the command. Also, if you set a derating factor on a hierarchical cell, the derating factor extends to cells and nets within and below the hierarchy.

In case of conflict between different set\_timing\_derate values specified for different levels of the design, the more detailed command (with the narrowest scope) has precedence. For example, the following commands have decreasing order of precedence:

If you use the <code>-derate</code> option of the <code>report\_timing</code> command, the timing report shows the derate factors applied to each cell and net.

To obtain a report on the current timing derating factors that have been set, use the report timing derate command. For example,

Use the <code>-include\_inherited</code> option to include reporting of derating values inherited from other objects, such as a lower-level cell that inherits its derating values from a higher-level cell. Otherwise, the command reports only the derating values set directly on the specified object.

### **Voltage and Temperature Scaling Between Libraries**

Design Compiler and IC Compiler can use "scaling library groups" to implement voltage and temperature scaling. To get the cell delays at intermediate voltage and temperature conditions, the tool interpolates between the data in separate libraries that have been characterized at different nominal voltage and temperature values. Scaling between the libraries is done during runtime of the tool.

To use this feature, the libraries in the scaling group must contain CCS timing models or mixed CCS and NLDM timing models. The cell data must be consistent with respect to cell names, number and names of pins, and number and names of timing arcs.

To specify the membership of libraries to scaling library groups, use the define\_scaling\_lib\_group command. To apply a defined scaling library group to the design or to selected objects in the design, use the set\_scaling\_lib\_group command. To create an intermediate operating condition, use the create\_operating\_conditions command. For example,

This example creates a one-dimensional scaling group consisting of two libraries characterized at two extreme voltages, 0.70 and 1.25 volts. It applies this scaling group to the design and selects the 1.25-volt library as the default operating condition for the design. Then it creates a new operating condition at 0.95 volts and applies it to two objects in the

design. The tool performs interpolation between the .70-volt and 1.25-volt libraries to obtain the timing characteristics at 0.95 volts, and uses that information for timing analysis of the two objects.

#### Note:

PrimeTime supports the define\_scaling\_lib\_group command but not the set\_scaling\_lib\_group command. Instead, PrimeTime uses the link\_path\_per\_instance variable and set\_min\_library command. In Design Compiler or IC Compiler, the write\_link\_library command writes out commands that set the link\_path\_per\_instance variable appropriately in PrimeTime.

To perform both voltage and temperature scaling at the same time, you would use four libraries in the scaling group rather than two, representing the four possible combinations of voltage and temperature extremes: high voltage and high temperature, high voltage and low temperature, low voltage and high temperature, and low voltage and low temperature.

### **Clock Reconvergence Pessimism Removal**

Clock reconvergence pessimism is an accuracy limitation that occurs when two different clock paths partially share a common physical path segment and the shared segment is assumed to have a minimum delay for one path and a maximum delay for the other path. This condition can occur any time that launch and capture clock paths use different delays, most commonly with on-chip variation analysis or timing derating. Automated correction of this inaccuracy is called clock reconvergence pessimism removal, or CRPR.

The tool performs clock reconvergence pessimism removal, when enabled, at the same time as regular timing analysis. You need to enable the clock reconvergence pessimism removal before you do timing analysis.

### **On-Chip Variation Example**

Consider the following command sequence for running on-chip variation analysis and the corresponding design in Figure 4-6:



Figure 4-6 Clock Reconvergence Pessimism Example

Figure 4-6 shows how the analysis is done. Each delay (considered equal for rising and falling transitions to simplify this example) has a minimum value and a maximum value computed for the minimum and maximum operating conditions.

The setup check at LD2/CP considers the clock path to the source latch (CLK to LD1/CP) at 100 percent worst case, and the clock path to the destination latch (CLK to LD2/CP) at 80 percent worst case.

Although this is a valid approach, the test is pessimistic because clock path1 (CLK to LD1/CP) and clock path2 (CLK to LD2/CP) share the clock tree until the output of U1. The shared segment is called the *common portion*, consisting of just cell U1 in this example. The last cell output in the shared clock segment is called the *common point*, which is the output of U1 in this case.

The setup check considers that cell U1 simultaneously has two different delays, 0.64 and 0.80, resulting in a pessimistic analysis in the amount of 0.16. This amount, obtained by subtracting the earliest arrival time from the latest arrival time at the common point, is called the *clock reconvergence pessimism*.

This inaccuracy also occurs in an analogous way for the hold test at the LD2 latch.

### **Reconvergent Logic Example**

Figure 4-7 shows a situation where clock reconvergence can occur, even in the absence of on-chip variation analysis. In this example, there is reconvergent logic in the clock network. The two clock paths that feed into the multiplexer cannot be active at the same time, but an analysis could consider both the shorter and longer paths for one setup or hold check.

Figure 4-7 Reconvergent Logic in a Clock Network



### **Setting Clock Reconvergence Pessimism Removal**

To enable clock reconvergence pessimism removal, set the control variable to true before you begin timing analysis, as follows:

```
prompt> set timing_remove_clock_reconvergence_pessimism true
```

By default, the variable is set to false and the feature is disabled. Enabling the feature results in a more accurate (less pessimistic) analysis but causes an increase in runtime and memory usage. Any change in this variable setting causes a complete timing update.

For the on-chip variation example shown in Figure 4-6, the timing report shows the pessimism removal value as follows:

Startpoint: LD1 (rising edge-triggered flip-flop clocked by CLK) Endpoint: LD2 (rising edge-triggered flip-flop clocked by CLK) Path Group: CLK

Path Group: CLI Path Type: max

| Point                            | Incr | Path   |
|----------------------------------|------|--------|
|                                  |      |        |
| clock CLK (rise edge)            | 0.00 | 0.00   |
| clock network delay (propagated) | 1.40 | 1.40   |
| LD1/CP (FD2)                     | 0.00 | 1.40 r |
| LD1/Q (FD2)                      | 0.60 | 2.00 f |

| U1/z (AN2)<br>data arrival time                                                                                                                           | 3.20                                | 5.20 f<br>5.20                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|---------------------------------------------------------------|
| clock CLK (rise edge) clock network delay (propagated) clock reconvergence pessimism clock uncertainty LD2/CP (FD2) library setup time data required time | 6.00<br>1.16<br><b>0.16</b><br>0.00 | 6.00<br>7.16<br><b>7.32</b><br>7.32<br>7.32 r<br>7.12<br>7.12 |
| data required time data arrival timeslack (MET)                                                                                                           |                                     | 7.12<br>-5.20<br>                                             |

Pessimism can also be introduced on paths that fan out from a clock source to the data pin of a sequential device, such as the path shown in Figure 4-8. (Technically, this is not considered clock reconvergence pessimism because the launching path is considered a data path, not a clock path.)

Figure 4-8 Timing Path Fanout from Clock Source to Data Pin



To remove pessimism for these paths, set the timing\_crpr\_remove\_clock\_to\_data\_crp variable to true before you begin timing analysis.

#### Note:

Calculating CRP for such paths involves analyzing the sequential device associated with each clock to data path separately in the timing analysis. This may cause a severe performance penalty during a timing update.

To specify whether to perform clock reconvergence pessimism removal on clock paths that have opposite-sense transitions in a shared path segment, set the timing\_clock\_reconvergence\_pessimism variable. You can set this variable to normal (the default setting) or same\_transition. For the default setting, the tool still performs clock reconvergence pessimism removal with opposite-sense transitions in the shared path segment. In that case, if the two transition types produce different correction values, the

smaller of the two values is used. For <code>same\_transition</code>, the tool performs clock reconvergence pessimism removal only if transitions in the shared path segment have the same sense.

You can set a threshold that allows the tool to ignore small amounts of clock reconvergence pessimism. For computational efficiency, the tool merges multiple points for CRPR calculations when the CRP differences between adjacent points are smaller than the specified threshold. This merging of nodes can reduce CPU and memory usage, without a significant loss of accuracy when an appropriate threshold is set.

The timing\_crpr\_threshold\_ps variable specifies the threshold. The units are picoseconds, irrespective of the time units of the technology library. By default, the variable is set to 20, which allows adjacent nodes to be merged when the difference in clock reconvergence pessimism is 20 ps or less.

For a good balance between performance and accuracy, try setting this variable to one-half the stage delay of a typical gate in the clock network. The stage delay is gate delay plus net delay. You might want to use a larger value during the design phase for faster analysis, and then a smaller value for sign-off accuracy.

### **Transparent Latch Edge Considerations**

For a path that ends at a transparent latch, the tool calculates two clock reconvergence pessimism values: one for rising edges and one for falling edges at the common node. The opening and closing clock edges are effectively shifted, each by an amount equal to its corresponding pessimism value, as indicated in Figure 4-9.

Figure 4-9 Clock Reconvergence Pessimism Removal for Latches



In practice, the opening-edge pessimism value affects the slack of nonborrowing paths and also reduces the amount of time borrowed for borrowing paths. Meanwhile, the closing-edge pessimism value increases the maximum amount of time borrowing allowed at a latch and reduces the amount of the violation for a path that fails to meet its setup constraint.

### **Reporting CRPR Calculations**

The report\_crpr command reports the calculation of clock reconvergence pessimism (CRP) between two register clock pins or ports. You specify the pins of the launch and capture registers, the clock, and type of check (setup or hold). For example,

The command generates a report showing the location of the common node, the launch and capture edge types (rising or falling), the four calculated arrival times at the common point (early/late, rise/fall), the calculated CRP values (rise and fall), and the values actually used for opening-edge and closing-edge pessimism removal.

The amount of CRP reported by <code>report\_crpr</code> can be slightly different from the amount reported by <code>report\_timing</code>. This is because <code>report\_timing</code>, for computational efficiency, "merges" multiple points for CRPR calculations when the CRP differences between adjacent points are too small to be significant.

# 5

## **Timing Constraints**

Timing analysis and timing optimization depend on constraints you specify, as described in the following sections:

- Input Delays
- Output Delays
- Drive Characteristics at Input Ports
- Port Load Capacitance
- Ideal Networks
- Case Analysis
- Mode Analysis
- Wire Load Models
- Timing Loops

### **Input Delays**

The set\_input\_delay command specifies the timing of external paths leading to an input port. An input delay is specifying an arrival time at an input port relative to a clock edge. This is the command syntax:

```
set_input_delay
  delay_value
  [-clock clock_name]
  [-clock_fall]
  [-level_sensitive]
  [-network_latency_included]
  [-source_latency_included]
  [-rise] [-fall]
  [-max] [-min]
  [-add_delay]
  port_pin_list
```

Applying the set\_drive or set\_driving\_cell commands to the port causes the port to have a cell delay that is the load-dependent value of the external driving-cell delay. To prevent this delay from being counted twice, estimate the load-dependent delay of the driving cell, then subtract that amount from the input delays on the port.

The input delay should equal the path length from the clock pin of the source flip-flop to the output pin of the driving cell, minus the load-dependent portion of the driving cell's delay. For example, see the external path for the L1 clock port to port IN1 in Figure 5-1.

Figure 5-1 Two-Phase Clocking Example for Setting Port Delays



When you use the set\_input\_delay command, you can specify whether the delay value includes the network latency or source latency. For more information, see the set\_input\_delay man page.

#### Example 1

If the delay from L1 clock port to IN1 (minus the load-dependent delay of the driving cell) is 4.5, this set\_input\_delay command applies:

```
prompt> set_input_delay 4.5 -clock PHI1 {IN1}
```

#### **Example 2**

If paths from multiple clocks or edges reach the same port, specify each one using the <code>-add\_delay</code> option. If you omit the <code>-add\_delay</code> option, existing data is removed. For example,

```
prompt> set_input_delay 2.3 -clock PHI2 -add_delay {IN1}
```

#### Example 3

In Figure 5-2, consider the path to input IN2.

Figure 5-2 Two-Phase Clocking



Assume that a rising signal on IN2 can occur 4.3 time units after the rising edge of clock PHI2 and a falling signal has a delay of 3.5 units to reach IN2 (the maximum and minimum times are the same in this case). Input delay is defined as

```
prompt> set_input_delay 4.3 -rise -clock PHI2 { IN2 }
prompt> set_input_delay 3.5 -fall -clock PHI2 { IN2 }
```

Now consider the delays leading to input port IN1. Paths from registers are clocked by two different clocks. To fully describe this situation, use the <code>-add\_delay</code> option to capture input delay information relative to both clocks. Enter

```
prompt> set_input_delay 2.7 -clock PHI1 -add_delay { IN1 }
prompt> set_input_delay 4.2 -clock PHI2 -add_delay { IN1 }
```

#### Example 4

This example shows a 7-ns input delay defined relative to clock CLK1. The command for defining the delay is

```
prompt> set_input_delay 7 IN1 -clock CLK1
```

Figure 5-3 Input Delay on CLK1



#### Example 5

This example shows a 7-ns input delay defined relative to clock CLK2. The command for defining the delay is

```
prompt> set_input_delay 7 IN2 -clock CLK2
```

Figure 5-4 Input Delay on CLK2



If the source of the delay is a level-sensitive latch, use the <code>-level\_sensitive</code> option. This allows PrimeTime to determine the correct single-cycle timing constraint for paths from this port. Use the <code>-clock\_fall</code> option to denote a negative level-sensitive latch; otherwise the <code>-level\_sensitive</code> option implies a positive level-sensitive latch.

To see input delays on ports, use the report\_port -input\_delay command.

To remove input delay information from ports or pins in the current design set using the set\_input\_delay command, use remove\_input\_delay. The default is to remove all input delay information in the port\_pin\_list.

### **Excluding Clocks**

PrimeTime considers the input delay on clock source ports or pins as source latency if the clock is propagated. The input delay can be relative to no clock, or to the clock of that source. The source latency value is added to the clock network delay to determine total latency.

A common mistake is to use the following command, which sets delay on all the inputs, including the clock input:

Use the <code>set\_clock\_latency</code> command with the <code>-source</code> option to define the actual source latency, if any.

### **Output Delays**

The set\_output\_delay command specifies output delays. An output delay represents an external timing path from an output port to a register. The maximum output delay value should be equal to the length of the longest path to the register data pin, plus the setup time of the register. The minimum output delay value should be equal to the length of the shortest path to the register data pin, minus the hold time.

This is the command syntax:

```
set_output_delay
  delay_value
[-clock clock_name [-clock_fall] [-level_sensitive]]
[-network_latency_included]
[-source_latency_included]
[-rise] [-fall]
[-max] [-min]
[-add_delay]
[-group_path group_name]
port pin list
```

To show output delays associated with ports, use report port -output delay.

To remove output delay from output ports or pins set through set\_output\_delay, use remove\_output\_delay. By default, all output delays on each object in the port or pin list are removed. To restrict the removed output delay values, use -clock, -clock\_fall, -min, -max, -rise, or -fall.

#### **Example 1**

To set an output delay of 4.3 relative to the rising edge of clock PHI1 on port OUT1 (see Figure 5-1 on page 5-2):

```
prompt> set_output_delay 4.3 -clock PHI1 {OUT1}
```

#### **Example 2**

If the combinational logic delay from a rising signal on port OUT1 reaches the register in 3.5 time units and there is a 0.3-unit library setup time for that register, the total output delay is 3.8 relative to the clock PHI1 rising edge. The maximum output delay is defined as

```
prompt> set_output_delay 3.8 -rise -clock PHI1 {OUT1}
```

#### Example 3

If the library hold time is 0.7, the minimum output delay is the minimum path length minus the library hold time (3.5 - 0.7). For example, enter

```
prompt> set output delay 2.8 -min -rise -clock PHI1 { OUT1 }
```

#### **Example 4**

In some cases, the relative clock for the output delay does not exist within the subdesign. You can use the <code>create\_clock</code> command to create a virtual clock that can be used in a set output delay command. For example, enter

```
prompt> create_clock -period 10 -waveform {3 8}-name off_chip_clk
prompt> set_output_delay 2.5 -clock off_chip_clk {OUT2}
```

### **Drive Characteristics at Input Ports**

You can define the drive capability of the external cell driving each input port. The tool uses this information to calculate the delay for the port and to produce an accurate transition time for calculating cell delays and transition times for the following logic stages.

The set\_driving\_cell command the driving cell so that timing calculations are accurate even if the capacitance changes. This command causes the port to have the transition time calculated as if the given library cell were driving the port.

For less precise calculations, you can use the <code>set\_drive</code> or <code>set\_input\_transition</code> command. The most recent drive command overwrites any setting made by an earlier command. For example, if you use the <code>set\_drive</code> command on a port and then use the <code>set\_driving\_cell</code> command on the same port, information from the <code>set\_drive</code> command is removed.

To obtain information about port settings, use the  $report\_port$  command. This is the command syntax:

```
report_port
  [-drive]
  [-verbose]
  [-physical]
  [-only_physical]
  [-nosplit]
  [-significant_digits digits]
  [port_list]
```

By default, the command reports all ports. Specify a port list to restrict the report to only those ports. Use the <code>-drive</code> option to get information about the drive capability of the port, the <code>-physical</code> option to get the physical location of the port, or <code>-verbose</code> to get all types of information about the port.

### **Setting the Port Driving Cell**

The set\_driving\_cell command models the external driver at an input port of the current design as the output of a library cell. The tool can then accurately model the drive capability of the external driver. This is the command syntax:

```
set_driving_cell
  [-lib_cell lib_cell_name]
  [-library lib]
  [-rise] [-fall]
  [-min] [-max]
  [-pin pin_name]
  [-from_pin from_pin_name]
  [-dont_scale]
  [-no_design_rule]
  [-none]
  [-input_transition_rise rtran]
  [-input_transition_fall ftran]
  [-multiply_by factor]
  port_list
```

The <code>set\_driving\_cell</code> command can be used instead of the <code>set\_drive</code> command to describe driver characteristics an input port. The <code>set\_driving\_cell</code> command works with all delay models. The <code>set\_driving\_cell</code> command removes any corresponding rise or fall drive resistance attributes (from <code>set\_drive</code>) on the specified ports.

By default, the <code>set\_driving\_cell</code> command takes into account the design rule constraints associated with the specified driving cell, in addition to the drive information used to compute the transition time of the input net. When you specify a driving cell, the design rule constraints are annotated on the input port of the block being synthesized. To use the driving cell only to compute input transition times, use the <code>-no\_design\_rule</code> option to <code>set\_driving\_cell</code>.

To display port transition or drive capability information, use the report\_port command with the -drive option.

With the <code>set\_driving\_cell</code> command, you can specify the input rise and fall transition times for the input of the driving cell by using the <code>-input\_transition\_rise</code> or the <code>-input\_transition\_fall</code> option. If no input transition is specified, the default is 0.

Table 5-1 summarizes the port attributes set by the set\_driving\_cell command in Design Compiler.

Table 5-1 Port Attributes Set by set\_driving\_cell in Design Compiler

| Attribute name                                                   | Attribute type | Value example |
|------------------------------------------------------------------|----------------|---------------|
| driving_cell_rise<br>driving_cell_fall                           | string         | "AN2"         |
| <pre>driving_cell_library_rise driving_cell_library_fall</pre>   | string         | "tech_lib"    |
| <pre>driving_cell_pin_rise driving_cell_pin_fall</pre>           | string         | "Z"           |
| <pre>driving_cell_from_pin_rise driving_cell_from_pin_fall</pre> | string         | "B"           |
| driving_cell_dont_scale                                          | Boolean        | TRUE          |
| driving_cell_multiply_by                                         | float          | 0.5           |

#### **Example**

Figure 5-5 shows driving cells set by the following set\_driving\_cell command examples.

Figure 5-5 Using set\_driving\_cell



In Figure 5-5, Port I1 is driven by a single IV cell. Because IV has only one output and one input, define the drive as follows:

```
prompt> set_driving_cell -lib_cell IV {I1}
```

Port I2 is driven by an AND2 cell. If the different arcs of this cell have different transition times, define the drive as follows:

```
prompt> set_driving_cell -lib_cell AND2 -pin Z -from_pin B {I2}
```

Port I3 has two drivers. Assuming that TS1 has the worst rise drive and TS2 has the worst fall drive, define the drive as follows:

```
prompt> set_driving_cell -lib_cell TS1 -rise {I3}
prompt> set_driving_cell -lib_cell TS2 -fall {I3}
```

Port I4 has two parallel drivers. In some technologies, this configuration is valid and reduces transition times by 50 percent. Use the multiplier option, as follows:

```
prompt> set_driving_cell -lib_cell IV -multiply_by 0.5 {I4}
```

### **Setting the Port Drive Resistance**

The set\_drive command defines the external drive strength as a resistance value for specified input ports. During optimization, the drive of an input port is used to calculate the timing delay to gates driven by that port. The external driver is modeled as the supply voltage connected in series with the specified resistance value.

This is the command syntax:

```
set_drive
   resistance
[-rise] [-fall]
[-min] [-max]
port_list
```

An alternative to using <code>set\_drive</code> is to use <code>set\_driving\_cell</code> or <code>set\_input\_transition</code>. The <code>set\_driving\_cell</code> command is usually the preferred method because it is the most realistic model. The <code>set\_drive</code> command is useful when you cannot specify a library cell, for example, when the driver is a custom block not in the library. In case of conflict, the command used most recently overrides earlier commands.

The following example sets the rise and fall drives of ports A, B, and C to 2.0

```
prompt> set_drive 2.0 {A B C}
```

The following example sets the drive resistance for all input ports:

```
prompt> set_drive 12.3 [all_inputs]
```

### **Setting a Fixed Port Transition Time**

The set\_input\_transition command defines a fixed transition time for input ports. The port has zero cell delay. PrimeTime uses the specified transition time only in calculating the delays of logic driven by the port. This is the command syntax:

```
set_input_transition
  transition
[-rise] [-fall]
  [-min] [-max]
  port list
```

A fixed transition time setting is useful for setting transition times for ports at the top level of a chip, where a large external driver and a large external capacitance exist. In this case, the transition time is relatively independent of capacitance in the current design. For more information, see the set\_input\_transition man page.

### **Removing Drive Information From Ports**

The commands shown in Table 5-2 remove drive information from ports.

Table 5-2 Commands to Remove Drive Information

| To remove this                                                                   | Use this                 |
|----------------------------------------------------------------------------------|--------------------------|
| Driving cell information from a list of ports                                    | remove_driving_cell      |
| Drive resistance                                                                 | set_drive 0.0            |
| Input transition                                                                 | set_input_transition 0.0 |
| Drive data and all user-specified data, such as clocks, input and output delays. | reset_design             |

### **Port Load Capacitance**

To accurately perform timing analysis, the tool needs information about the external load capacitance of nets connected to top-level ports, including pin capacitance and wire capacitance. You can explicitly specify the load capacitance on a port with the <code>set\_load</code> command. This is the command syntax:

```
set_load
  value
  objects
[-subtract_pin_load]
[-min]
[-max]
[[-pin_load] [-wire_load]]
```

The <code>-wire\_load</code> and <code>-pin\_load</code> options are useful when you know the total value of the loads contributed by the external nets. For example, use these options with back-annotated nets or with segmented wire loads where the wire load model is insignificant and you only want the total capacitive load caused by the external net.

If you use both the  $-wire_load$  and  $-pin_load$  options, the load value you define is used for both the pin load and wire load of the port. The  $-pin_load$  option is the default. However, with both the options, you can distinguish between the pin load and wire load portions of the total port load.

#### **Example 1**

To specify the external pin capacitance of ports, enter

```
prompt> set_load -pin_load 3.5 {IN1 OUT1 OUT2}
```

You also need to account for wire capacitance outside the port. For prelayout, specify the external wire load model and the number of external fanout points.

#### Example 2

For post-layout, specify the external annotated wire capacitance as wire capacitance on the port. For example, enter

```
prompt> set_load -wire_load 5.0 {OUT3}
```

To remove port capacitance values, use the remove\_attribute command.

### **Ideal Networks**

An ideal network is a network of cells, nets, and pins that are exempt from timing updates, timing optimization, and DRC fixing—that is, max\_capacitance, max\_fanout, and max\_transition design rules are ignored. As a result, runtime and timing optimization are improved. In addition, the tool does not optimize away the source port or leaf-level pin of the ideal network.

For example, if you define as ideal nets certain high-fanout nets that you intend to synthesize separately, such as scan-enable and reset nets, you can reduce runtime by avoiding unnecessary retiming and unwanted design changes during optimization.

When you specify the source port or leaf-level pin of an ideal network, the nets, cells, and pins in the transitive fanout of this source are treated as ideal objects. Ideal objects have the following properties:

- They are marked as ideal.
- They are not affected by timing updates, delay optimization, or DRC fixing.
- They are assigned ideal timing properties: ideal latency, ideal transition time, and ideal capacitance of zero. You can change the latency and transition values by using the set\_ideal\_latency and set\_ideal\_transition commands, respectively.

The tool disables delay optimization of an ideal network by marking the cells and nets in the network as <code>dont\_touch</code>. In addition, the tool disables DRC fixing by setting the DRC cost to 0 for the network. The <code>size\_only</code> attribute is set on the cell that contains or drives the source. This guarantees that the ideal network source is not lost during compile.

#### Note:

Although clock nets and networks are ideal by default, you should not use the set\_ideal\_network command to modify the properties of these networks. To prevent clock nets from being treated as ideal nets, use the set\_auto\_disable\_drc\_nets -clock false Or set\_propagated\_clock command.

### **Propagation of the Ideal Network Property**

When you specify the source object of an ideal network, all the nets, cells, and pins in the transitive fanout of the source objects are treated as ideal. Any input port or internal pin of the current design can be a source object, except for a pin at a hierarchical boundary.

The tool automatically spreads the ideal network property to the nets, cells, and pins in the transitive fanout of the source object, according to certain propagation rules. The tool propagates the ideal network property across logic gates and hierarchies. Propagation of the ideal network property stops at a sequential cell or a boundary cell (a cell in which the propagation rules are not met). The pins where propagation stops are known as network boundary pins; they are ideal pins.

Propagation of the ideal network property is governed by the following rules:

- A pin is treated as ideal if it is one of the following:
  - A pin specified in the object list of the set\_ideal\_network command
  - A driver pin and its cell is ideal
  - A load pin attached to an ideal net
- A net is treated as ideal if all its driving pins are ideal.
- A combinational cell is treated as ideal if either:
  - · All its input pins are ideal, or
  - An input pin is attached to a constant net and all other input pins are ideal. Note that an object with the case analysis attribute is not treated as constant.

#### Note:

Ideal network propagation can traverse combinational cells, but it stops at sequential cells, even if the sequential cells are connected to ideal clock pins.

If an ideal network overlaps a clock network, the clock timing information, including clock latency and transition values, overrides the ideal timing for the clock portion of the overlapped networks.

### **Creating Ideal Networks**

You use the  $set\_ideal\_network$  command to create ideal networks. This is the command syntax:

```
set_ideal_network
  object_list
[-dont_care_placement]
[-no_propagate]
```

Specify a list of objects (ports, pins, or nets) as the sources of the ideal network.

If you specify a net, the net's global driver pins or ports are marked as ideal network sources. That is, the ideal network property is applied to the global driver pins or ports of the specified net. This ensures that the ideal network property is not lost even if the net is optimized away.

To prevent the ideal network from being considered during placement, use the -dont\_care\_placement option.

To prevent the ideal network from being propagated through logic gates, use the -no\_propagate option.

#### **Example 1**

Consider the following command and the resulting ideal network in Figure 5-6.

```
prompt> set_ideal_network [get_pins IV1/Z]
```

Figure 5-6 Ideal Networks



In Figure 5-6, pin IV1/Z is the source of the ideal network. The ideal network property is set on IV1/Z and propagated along the nets, cells, and pins in the transitive fanout of IV1/Z. In addition, the dont\_touch attribute is propagated to these nets, cells, and pins. Propagation stops at the sequential cell. In addition, the size\_only attribute is set on the driver cell IV1 of pin Z.

#### Example 2

Consider the following command and the resulting ideal network in Figure 5-7.

prompt> set\_ideal\_network P1

Figure 5-7 Propagation of the Ideal Network



In Figure 5-7, one of the inputs of the AND gate is not ideal. The ideal network property is set on P1 and propagated along the nets, cells, and pins in the transitive fanout of P1. In addition, the <code>dont\_touch</code> attribute is propagated to these nets, cells, and pins. The tool propagates the ideal network property across the hierarchical boundary from the top-level block to subblock A. Propagation of the ideal network property stops at the sequential cell FF2 and gate AND1. The <code>size\_only</code> attribute is not set on any cell because the source P1 of the ideal network is a port.

### **Removing Ideal Networks**

To remove ideal networks and restore objects in the ideal network to their initial, nonideal state, use the following commands:

• remove\_ideal\_network

This command restores the cells, nets, and pins in the ideal network to their initial, nonideal state.

remove\_ideal\_net [get\_nets net]

This command restores the ideal net set by the set\_ideal\_network -no\_propagate command to its initial, nonideal state.

• remove\_attribute [get\_nets net] ideal\_net

This command restores the ideal net set by the set\_ideal\_net command to its initial, nonideal state.

### **Reporting Ideal Networks**

Use the following commands to get more information about ideal networks:

- report\_ideal\_network
- report\_attribute

This command reports attributes associated with cells, nets, and pins. If you use this command to report attributes set on an ideal net, attributes set by both the set\_ideal\_net command and the set\_ideal\_network -no\_propagate command are reported.

report\_net

This command reports net information; ideal nets are indicated by "I".

Commands such as report\_timing, report\_cell, and report\_net indicate the ideal network property propagated to nonsource objects of an ideal network, as well as the source ports and pins of the network. The report\_attribute command and the get\_attribute command, however, indicate the ideal network property only for the source ports and pins of the network. The propagated attribute is not shown.

### **Retrieving Ideal Objects**

Use the following commands to retrieve ideal objects.

- get\_nets -filter "ideal\_net == true"
  - This command returns ideal nets set by the set\_ideal\_net command or the set ideal network -no propagate command.
- get\_pins -filter "ideal\_network\_source == true"

This command returns pins that are ideal network sources. Additionally, if you use the ideal\_network\_options == 1 filter, the command returns only the ideal network source pins that were set by the set\_ideal\_network -no\_propagate command.

• get ports -filter "ideal network source == true"

This command returns ports that are ideal network sources. Additionally, if you use the ideal\_network\_options == 1 filter, the command returns only the ideal network source ports that were set by the set\_ideal\_network -no\_propagate command.

### **Setting Ideal Latency and Ideal Transition Time**

The default latency and transition values for ideal networks and ideal nets is zero. You can override these defaults by using the following commands:

- set ideal latency
- set ideal transition

#### Note:

The timing of ideal networks and ideal nets is updated whenever you execute either of these commands.

You can use these commands to set the ideal latency and ideal transition on the source pin of an ideal net or network and on any nonsource pin of an ideal network. The specified values override any library cell values or net delay values. For ideal networks, the ideal latency and transition values are propagated from the source pins to the network boundary pins.

The total ideal latency at any given point of an ideal network is the sum of the source pin ideal latency and all the ideal latencies of the leaf cell pins along the path to the given point. The ideal transition values specified at the various source and leaf cell pins are independent and noncumulative. The transition for an unspecified input pin is the ideal transition of the closest pin with a specified ideal transition value. This rule applies to boundary pins as well.

The set\_input\_delay command is applicable to ideal networks. This delay is treated as the off-block latency or source latency.

You can remove ideal latency and ideal transition values by using the following commands:

- remove\_ideal\_latency
- remove\_ideal\_transition

These commands remove the ideal latency and ideal transition values from the specified source pins. In the case of ideal networks, the command also removes the ideal latency and transition values from any nonsource pins on which they were set and from any pins to which the ideal property was propagated. The default value of zero is restored to the ideal pins.

### **Case Analysis**

Case analysis lets you perform timing analysis using logic constants or logic transitions on ports or pins to limit the signals propagated through the design. Setting a case analysis with a logic constant propagates the constant forward through the design, then disables paths where the constant is propagated. Setting a case analysis with a logic transition, either rising or falling, eliminates certain paths by limiting the transitions considered during analysis.

#### **Example 1**

In the multiplexer in Figure 5-8, logic 0 is set on the select control signal. This disables the arc from B to Z because the constant blocks the data from B to Z.

Figure 5-8 Constant Blocking of Data



#### Example 2

When case analysis propagates a constant to a sequential element's asynchronous preset or clear pin, the sequential cell outputs also propagate the constant 1 or 0, as shown in Figure 5-9.

Figure 5-9 Constant Propagation Through an Asynchronous Input



#### Example 3

When your design uses scan flip-flops, case analysis is useful for disabling the scan chain. To do this, set the scan mode control pin to the constant value that disables the test mode. The tool propagates the test-mode constant value to the scan-mode pin of each scan flip-flop. Case analysis determines which timing arcs to disable, as shown in Figure 5-10.

Figure 5-10 Case Analysis Disabling Timing Checks



For example, to set case analysis with a 0 value on the SCAN\_MODE input port, enter

prompt> set\_case\_analysis 0 [get\_ports SCAN\_MODE]

#### Example 4

Setting a case analysis for a transition can be useful for analyzing the behavior of a circuit for a specific situation. For example, in the circuit shown in Figure 5-11, a rising-edge transition on the reset input brings the device out of the reset mode.

Figure 5-11 Case Analysis for a Rising Edge



To analyze the timing of the circuit coming out of reset mode, you are only concerned about rising edges on the reset input, not logic 0, logic 1, or falling edges. To set case analysis in this situation, enter the following syntax:

```
prompt> set_case_analysis rising [get_ports RESET]
```

You can also specify logic constants by using the <code>set\_logic\_one</code> and <code>set\_logic\_zero</code> commands. Case analysis treats these logic constants as case analysis constants for the purposes of timing and costing the design. Also, the tool ties unconnected pins to constants, and these constants can be used to disable arcs based on case analysis.

The tool performs constant propagation if the <code>set\_case\_analysis</code> command has been used or if the <code>case\_analysis\_with\_logic\_constants</code> variable has been set to true. You can disable propagation of case analysis constants by setting the <code>disable\_case\_analysis</code> variable to true.

### **Reporting Case Analysis**

The report\_case\_analysis command reports the case analysis values. For example,

Using the -all option of the command reports both the built-in logic constant pins and the case analysis values set on the design. For example,

```
prompt> report_case_analysis -all
...
```

| Pin name                   | User case analysis value |
|----------------------------|--------------------------|
| test_port<br>U1/U2/core/WR | 0                        |
| Pin name                   | User case analysis value |
| HRS<br>ALARM<br>MINS       | 1<br>1<br>1              |

The report\_disable\_timing command reports timing arcs that have been disabled by various causes, including case analysis. For example,

### **Removing Case Analysis**

The remove\_case\_analysis command removes case analysis values. For example, to remove case analysis values from the test port input port, enter the following syntax:

```
prompt> remove_case_analysis [get_ports test_port]
```

To suppress propagating logic constants (including those set with case analysis and pins tied to logic high or low), set the disable\_case\_analysis variable to true.

### **Constant Propagation Log File**

When the tool disables a timing arc, knowing the exact origin of the constant value propagated to a given pin of the design might be difficult. If you would like the tool to keep a log file containing the constant propagation information so that you can later track down the point of origin, set the <code>case\_analysis\_log\_file</code> variable to a file name. The constant propagation process is logged to the named file.

#### **Example**

This command sequence sets case analysis and reports the disabled timing arcs to the log file my design cnst.log for the example circuit.

```
prompt> set_case_analysis 0 {get_port "A"}
prompt> set_case_analysis 1 {get_port "B"}
prompt> set case_analysis_log_file my_design_cnst.log
```



In the example, the only arc that the tool disables is the arc in U5 from U5/A to U5/Z. U5/A is at constant value 0 and no constant is propagated to U5/Z. The constant propagation log file my\_design\_cnst.log looks like this:

```
*********
Report : case_analysis propagation
Design : my_design
Version: 2000.11
*********
1.1 Forward propagation on NET pins (level 1)
 Propagating logic constant '0' from pin 'A' on net 'A':
   > pin 'U1/A' is at logic '0'
 Propagation of logic constant '1' from pin 'B' on net 'B':
   > pin 'U4/B' is at logic '1'
1.2 Forward propagation through CELLS (level 1)
 Cell 'U1' (libcell 'IV') :
   input pin U1/A is at logic '0'
   > output pin 'U1/Z' is at logic '1'
5.1 Forward propagation on NET pins (level 5)
-----
 Propagating logic constant '0' from pin 'U4/Z' on net
`w4':
   > pin 'U5/A' is at logic '0'
5.2 Forward propagation through CELLS (level 5)
_____
6. End of Logic Constant Propagation
```

### **Usage Example**

The following script example shows how to use case analysis in the Design Compiler flow.

```
read_verilog design_B_rtl.v
current_design design_B
link
source design_B_constraints.con
set_case_analysis 1 [get_ports {...}]
set_case_analysis 0 [get_ports {...}]
set disable_case_analysis false
set case_analysis_log_file "design_B_case_analysis.log"
compile
report_case_analysis -all
report_disable_timing
report_timing
...
remove_case_analysis [get_ports {...}]
...
```

### **Mode Analysis**

Library cells and timing models can have operating modes defined in them, such as read and write modes for a RAM cell. Each mode has an associated set of timing arcs that the tool analyzes while that mode is active. The timing arcs associated with inactive modes are not analyzed. In the absence of any mode settings, all modes are active and all timing arcs are analyzed.

You can set cell modes directly on cell instances with the <code>set\_mode</code> command. For example, <code>set\_mode</code> <code>READ</code> <code>{U1}</code> sets the READ mode on cell instance U1. Alternatively, you can enforce an operating mode using case analysis. For example, if a cell U1 has a cell mode called READ which is defined to be active when input RW is 0, setting or propagating a case analysis value of 0 on the U1/RW input activates the READ mode and deactivates all other modes for that cell. The <code>set\_case\_analysis</code> <code>0</code> <code>[get\_pins U1/RW]</code> command sets a logic <code>0</code> directly on the RW pin of U1.

### Mode Groups

A library cell with modes can have one or more mode groups defined. Within each group, there are two possible states: all modes enabled (the default), or exactly one mode enabled with all other modes disabled. Often there is only one mode group.

Each cell mode group has a number of cell modes. Each cell mode is mapped to a number of timing arcs in the library cell. Every instance of that library cell has these cell mode groups together with the cell modes. For example, a typical RAM block can have read, write,

latched, and transparent modes. You can group the read and write modes, then group the latched and transparent modes in a different mode group. The advantage of grouping modes is that when you set a cell mode, the tool makes the corresponding mutually exclusive modes inactive.

For example, specifying the RAM block for the read mode implicitly specifies that the write mode is inactive, irrespective of any setting for the transparent and latched modes. Similarly, specifying the RAM block for the latched mode implies that transparent mode is inactive, irrespective of the read and write mode setting. The two mode groups (read/write and transparent/latched) are independent.

By default, all cell modes are enabled in each cell instance. Using the set\_mode command, you can set each cell mode group to have one mode enabled and all other modes disabled. When a mode is disabled, all timing arcs in that cell mapped to that mode are disabled.

### **Setting Modes Using Case Analysis**

Some library cells and timing models have conditional modes defined in them. This means that a mode selection is invoked by the logical conditions at the cell inputs. For example, the read mode of a RAM cell could be invoked by a logic 0 on the read/write input pin.

When you set the controlling logic value on the input pin using case analysis or when case analysis values are propagated to that pin, the cell is implicitly placed into the appropriate analysis mode.

#### **Example**

In this RAM example, the address input pins are A0, A1, and A2; and the data I/O pins are D0, D1, D2, and D3. The RAM cell can be operated in read and write modes.



The read\_write pin of the cell controls the read/write mode of the RAM. If the RAM is modeled with the following mode and condition association in the Liberty modeling language, you can perform the read and write mode analysis by setting logic values on the read\_write input pin:

```
cell(RAM) {
  mode_definition(read_write) {
    mode_value(read) {
      when : "read_write";
      sdf_cond : "read_write == 0";
    }
  mode_value(write) {
      when : "read_write";
      sdf_cond : "read_write == 1";
    }
  }
  ...
}
```

To enable the read mode in the tool, enter

```
prompt> set_case_analysis 0 [get_ports read_write]
```

To enable the write mode in the tool, enter

```
prompt> set_case_analysis 1 [get_ports read_write]
```

Setting or propagating a logic value to the read\_write pin implicitly selects the corresponding mode and disables the other mode. Only the timing arcs associated with the active mode are used in the timing analysis.

When no modes in a mode group are selected by case analysis or other mode selection methods, all of the modes are enabled. The default mode is enabled if no mode is selected.

# **Setting Modes Directly on Cells**

To specify the active cell modes directly for cell instances in the design, use the following command:

```
prompt> set_mode cell_mode_list instance_list
```

For example, to set the U1/U2/core cell to read mode, enter

```
prompt> set_mode read U1/U2/core
```

This makes the read mode active and the other modes inactive for the U1/U2/core cell.

cell\_mode\_list is a list of modes to be made active, no more than one mode per mode group. If the cell has only one mode group, you can list only one mode to be made active.

instance\_list is a list of instances in the design to be placed into the specified mode.

To cancel the mode selection and make all modes active for the U1/U2/core cell, enter

prompt> reset\_mode U1/U2/core

# **Reporting Modes**

prompt> report\_mode

The report\_mode command reports on modes that have been defined or set in the design. For example, to get a cell mode report:

Cell Mode(Group) Status

Uram1/core(RAM2\_core) read(rw) ENABLED

Write(rw) ENABLED

Uram2/core(RAM2\_core) read(rw) ENABLED

write(rw) ENABLED

The report shows the name of each cell instance with a mode setting, the possible mode settings and group names for the cell, the current status of each mode (enabled or disabled).

### Wire Load Models

For timing analysis performed before placement and routing, Design Compiler must estimate the wire delays. The simplest estimation method is the wire load model, which gets a rough value for the total wire capacitance, based on the size of the chip and the fanout of the net. Larger chip sizes and larger fanouts are assumed to result in longer wires and more resistance and capacitance. Wire load models are not used in IC Compiler because accurate wire information is available from the layout database.

For logic synthesis, you should use Design Compiler with topographical technology, if available, because it produces better results than wire load models. However, if you are not using Design Compiler in topographical mode, you can use wire load models to estimate the capacitance, resistance, and area of nets before floorplanning or layout. The wire load models provided in the technology library define the fanout-to-length relationships.

#### Note:

Wire load models are used only with Design Compiler running in standard mode, not topographical mode. Design Compiler with topographical technology and IC Compiler have better wire estimation methods, so wire load models are not used with these tools.

With wire load models, Design Compiler estimates the wire lengths of pin-to-pin connections based on fanout count, and then uses those estimates to calculate the effects of cell placement and wire routing. Fanout is the total number of pins on the net, excluding the driver pin.

The wire load model is defined in the library specification. In Liberty library syntax, the wire\_load group defines the wire loads. For more information, see the Library Compiler documentation.

Design Compiler determines which wire load model to use for a design according to the wire load model you define with the <code>set\_wire\_load\_model</code> command, the wire load indicated by the technology library's <code>wire\_load\_selection</code> group, or the wire load model identified by the <code>default\_wire\_load</code> attribute in the library, in that order. If none of these items are defined, no wire load model is used. and the net resistance, capacitance, and delay values are zero.

### Net Capacitance, Resistance, and Area Calculation

To calculate the capacitance of a net, Design Compiler performs the following steps:

- 1. Determines the fanout of the net.
- 2. Looks up the length in the wire load model.
- 3. Calculates the capacitance by multiplying the length by the capacitance coefficient in the wire load model.

#### Example

Suppose that a wire load model is defined as follows in the library:

To determine lumped net capacitance, total net resistance, and the design area due to the net, Design Compiler multiplies the capacitance, resistance, and area scaling factors by the estimated wire length.

Design Compiler calculates the net fanout value as the total number of pins on the net excluding one driver pin. For example, on a net with 2 fanin pins and 3 fanout pins, the fanout value is

```
(2 + 3) - 1 = 4
```

It calculates the lumped net capacitance by multiplying of the estimated wire length by the capacitance factor 2.0. For a fanout value of 4, the last fanout\_length defines the wire length as 4.4, resulting in a calculated lumped net capacitance of

```
2.0 * 4.4 = 8.8
```

It calculates the total net resistance by multiplying the estimated wire length by the resistance factor, yielding a value of

```
4.4 * 100.0 = 440.0
```

When calculating pin-to-pin RC delays, Design Compiler interprets the total net resistance on the basis of the current operating condition's tree\_type attribute.

Design Compiler calculates the net area by multiplying the estimated wire length by the area factor, yielding a value of

```
4.4 * .5 = 2.2
```

Design Compiler uses the net area to measure the impact of different optimization possibilities on the total design area of the chip. An accurate net area estimate guides Design Compiler in selecting the best optimization for minimizing area.

Design Compiler uses interpolation between and extrapolation beyond the library-defined wire load values.

# **Choosing a Wire Load Model**

The choice of wire load model depends on how the design is ultimately implemented. Hierarchy restrictions imposed on layout results in more accurate wire load estimates.

Wire load models are typically provided for different sizes of designs based on the observation that blocks of similar size generally exhibit similar fanout-to-length relationships. A wire load model must completely contain the design block under consideration.

If a design is not limited to one contiguous region of the physical chip, the wire load model must reflect that its nets can span the whole chip. In this case, the size of the block that completely contains the design is identical to the size of the chip. If a design is limited to a contiguous region of the physical chip, use a wire load model created for designs of the same size. Nets fully enclosed within the design are typically shorter and more predictable than those that potentially span the whole chip.

Another criterion for selecting a wire load model is the degree of pessimism used in its creation. When the potential exists for significantly underestimating the length of a net, use a wire load model that employs pessimism. By using a more pessimistic wire load model in the appropriate situations, you are less likely to have design violations after layout. Consult your library supplier for details about how the wire load models provided with the library are created.

### **Wire Load Model Modes**

The wire load model mode defines the wire load model to use for nets in subdesigns. Technology libraries have a <code>default\_wire\_load\_mode</code> attribute that defines the default mode. You can override a mode by using the <code>set\_wire\_load\_mode</code> command. This is the command syntax:

```
set wire load mode top | enclosed | segmented
```

Figure 5-12 shows how the span of a net determines the wire load models used in the each of the available mode settings.

Figure 5-12 Wire Load Model Modes



The "top" setting causes the wire load model and cell area for the top level to be used. Wire load models set on subdesigns have no effect. The top mode models nets as if the design has no hierarchy; it is pessimistic.

The "enclosed" setting causes the wire load model and the cell area of the smallest design that fully encloses the net to be used. If the design enclosing the net has no wire load model, the design hierarchy is traversed upward until a wire load model is found. The enclosed mode is more accurate than the top mode when cells in the same design are placed in a contiguous region during layout.

The "segmented" setting causes the sum of the cell areas of the designs containing the net to be used. Nets crossing hierarchical boundaries are divided into segments (part of the net is outside the module). Each net segment is estimated from the wire load model of the design containing the segment. If the design enclosing a segment has no wire load model, the design hierarchy is traversed upward until a wire load model is found.

If you want to set the lower blocks in a design to a mode other than top mode, you must set the TOP design to enclosed or segmented mode.

### **Examples**

To set the model my\_model on a design, enter

```
prompt> set_wire_load_model my_model
```

If the current library does not define a default mode, Design Compiler searches in the libraries in the link\_library.

To set the mode for the current design to top so that all nets use the same model (wire load models set on subdesigns are ignored), enter

```
prompt> set_wire_load_mode top
```

In a hierarchical design, to cause each net to use the model of the lowest-level block that completely contains that net, enter

```
prompt> set_wire_load_mode enclosed
```

In a hierarchical design, to cause nets to be divided into segments (as the nets cross block boundaries) and to estimate each net segment from the wire load model of the block containing the segment, enter

```
prompt> set_wire_load_mode segmented
```

#### Note:

The default value for the set\_wire\_load\_mode command is top. The wire\_load\_mode attribute cannot be removed. It can only be changed by using the set\_wire\_load\_mode command.

# **Setting a Wire Load Model**

The set\_wire\_load\_model command can be used to define a wire load model for designs, hierarchical cells, and ports. The wire load model you define with set\_wire\_load\_model overrides the default models.

You can use the <code>set\_wire\_load\_model</code> command to define an external wire load model for a port. The wire load model of a port can affect the calculated wire load of the net connected to the port.

If you set a wire load model on a design, automatic wire load selection is disabled for that design. In the presence of physical hierarchy, wire loads set on subdesigns are ignored.

The set\_wire\_load\_model command does not assume a default wire load mode. You use the set\_wire\_load\_mode command to explicitly set the wire load mode before you use the set\_wire\_load\_model command.

#### The syntax is

```
set_wire_load_model
  -name model_name
[-library library_name]
[-min] [-max]
[ object_list ]
```

#### **Examples**

```
prompt> set_wire_load_model -name "60x60"
Using wire_load model '60x60' found in library 'my_lib'.
```

To remove the wire\_load\_model attribute, use the remove\_wire\_load\_model command. For additional information, refer to the man pages.

# **Local Link Library Usage**

The set\_wire\_load\_model command searches the design's local link library before searching the system link library.

During compilation or translation, Design Compiler searches the link library for the default values. During the update\_timing or characterize commands, Design Compiler searches the first library on the link path for the default values. If Design Compiler cannot find the default values, it uses the following values:

Use the following commands to indicate a library name:

```
set_wire_load_model -name model_name -library library_name
set_operating_conditions -library library_name
```

The <code>library\_name</code> must either be a fully defined file name or exist in memory. If the requested information (wire load or operating conditions) is not in <code>library\_name</code>, Design Compiler searches the libraries in the link path. When Design Compiler finds the information, it reports the library name. Design Compiler never searches the link library unless you define it as <code>library\_name</code>.

For more information about link libraries, see the Design Compiler User Guide.

# **Setting a Wire Load Selection Group**

The set\_wire\_load\_selection\_group command sets the wire load selection group used to determine the wire load model when auto\_wire\_load\_selection is set to true.

The set\_wire\_load\_selection\_group command does not assume a default wire load mode. You can use the set\_wire\_load\_mode command to explicitly set the wire load mode to enclosed. This is the command syntax:

```
set_wire_load_selection_group
  [-library lib_name]
  [-min] [-max]
```

To remove the wire\_load\_selection\_group attribute, use the remove\_wire\_load\_selection\_group command. For additional information, refer to the man pages.

### Wire Load Models for Hierarchical Cells

To define distinct wire load models for hierarchical cells in the top-level design, define wire load models at the design level and at the instance level. When defining your wire load models, remember the following:

- Instance-level wire load settings take precedence over design-level wire load settings
- Design Compiler selects a wire load model based on the total cell area of the design if
  you designate top as the wire load mode for a design that has no wire load model defined
  (for the top most level) and if the first library in the link path has a wire load selection table

You can use the set\_wire\_load\_min\_block\_size command to set a minimum block size for the design.

# **Selecting the Wire Load Model Automatically**

If no wire load model is defined for a design, Design Compiler automatically selects a default wire load model based on area. The cell area used to select a wire load model for a net is determined by the wire load mode. Design Compiler searches the first library in the link path (or the first library in the design's local\_link\_library) for a default wire load.

- If the library contains a wire\_load\_selection group definition, Design Compiler uses the cell area of the current\_design to select the wire load model.
- If the library does not contain a wire\_load\_selection group definition, Design Compiler uses the default\_wire\_load for the library.
- If the library contains neither a wire\_load\_selection group nor a default\_wire\_load, Design Compiler does not select a wire load model and no wire load model is used.

If you set a wire load model on a design, automatic wire load selection is disabled for that design.

#### Note:

On large designs, using automatic wire load selection based on area is not recommended, because excessive runtimes might result.

# **Defining the Minimum Block Size**

Use the set\_wire\_load\_min\_block\_size command to define the smallest block size to be laid out contiguously in a design. Use this command when the logical hierarchy is decomposed into subblocks that have no physical meaning and should not be considered in selection of a wire load model. Design Compiler selects a wire load for each design on the basis of a cell area that is no less than the value defined with the set wire load min block size command.

### Example

```
wire_load("05x05") {
    resistance: 0;
    capacitance: 1;
    area: 0;
    slope: 0.186;
    fanout_length(1,0.39);
wire_load("10x10") {
    resistance: 0;
    capacitance: 1;
    area: 0;
    slope: 0.311;
    fanout_length(1,0.53);
```

```
default_wire_load: "15x15";
wire_load_selection() {
    wire_load_from_area (0,100,"05x05");
    wire_load_from_area (150,200,"10x10");
}
```

A design with an area larger than the range defined in the wire\_load\_from\_area definition is assigned the wire load of the next area range. For example, a design with area 120 lies between the defined intervals 0–100 and 150–200, so the design is assigned the higher of the two wire loads, 10x10.

A design must be mapped to determine the total area. For an unmapped design, if the default\_wire\_load attribute is not defined in the library, no wire load is used during mapping.

The wire load is automatically selected before and during a timing operation and design modification operation such as with update\_timing, report\_timing, or compile.

Design Compiler selects a wire load model before compile or translate. If the design is not mapped, Design Compiler uses either the default or no wire load model.

Design Compiler resets the wire load model after structuring or mapping and before gate-level optimization, before buffering, and at the end of optimization.

An update of the wire load model can create a new violation. In this case, you must rerun compile -incremental\_mapping.

# **Reporting Wire Load Models**

You can get information about wire load models for designs, ports, or libraries, using the commands listed in Table 5-3.

Table 5-3 Commands for Reporting Wire Load Information

| To report this                                                                                            | Use this command |
|-----------------------------------------------------------------------------------------------------------|------------------|
| The wire load models associated with a design                                                             | report_wire_load |
| The wire load model and mode for the current design and the libraries linked to the design                | report_design    |
| The wire load model of the output ports of a design                                                       | report_port      |
| The wire load models defined in a specified library and wire load selection tables defined in the library | report_lib       |

The report wire load command provides a list of all wire load model characteristics set on a design. This command reports the characteristics of a specific wire load model set on a design or library. By default, all wire load models set on the current design are reported.

The report\_wire\_load command is similar to the report\_lib command, but it also reports the statistics of how the wire load model was created. This is the command syntax:

```
report wire load
[-design design_name]
[-name model_name]
[-libraries]
 [-nosplit]
```

The report wire load -libraries command generates a report similar to the following:

Wire Loads Report

Wire load model: counter\_wl

Location : counter (design)

: 100 Resistance Capacitance : 1 Area : 0 Slope : 1.19097

| Fanout | Length | Points | Average<br>Cap | Standard<br>Deviation | % Standard<br>Deviation |
|--------|--------|--------|----------------|-----------------------|-------------------------|
| 1      | 1.00   | 20     | 1.00           | 0.00                  | 0.00                    |
| 2      | 2.31   | 3      | 2.31           | 0.27                  | 11.78                   |
| 3      | 3.50   | 3      | 3.50           | 0.24                  | 6.73                    |
| 4      | 4.69   | 6      | 4.69           | 0.45                  | 9.62                    |
| 5      | 5.89   | 1      | 5.89           | 0.11                  | 1.95                    |

Weighted Average Standard Deviation: 3.49

Wire load model: top\_cluster/cluster\_1\_wl

Location : top\_cluster/cluster\_1 (cluster)
Resistance : 100
Capacitance : 1 Area 0 : 1 Slope

| Fanout | Length | Points |      |      | % Standard Deviation |  |
|--------|--------|--------|------|------|----------------------|--|
| 1      | 1.00   | 3      | 1.00 | 0.00 | 0.00                 |  |

Weighted Average Standard Deviation: 0.00

Wire load model: 10x10

Location : my\_lib (library)
Resistance : 100

Resistance : 100 Capacitance : 1 Area

Slope : 0.311

Average Standard % Standard
Fanout Length Points Cap Deviation Deviation

The report contains the following types of information:

#### Location

Specifies where the wire load model was found. If a wire load model is on a design and in a library, the design location is indicated.

Resistance, Capacitance, and Area

0.53

Reports the values per unit length.

### Slope

Reports the slope of the wire load model after the last fanout value.

### **Points**

Specifies the number of points used for a fanout. A high number of points implies that a good population was used to create a statistically more accurate fanout length estimate. If the model was not created from back-annotation, only fanout and length are reported.

### Average Cap

Lists the average capacitance, which is directly proportional to length. This is the average capacitance back-annotated and modified by smoothing and trimming.

#### Standard Deviation

Reports the average difference between each point and the average.

# **Timing Loops**

If a timing loop is discovered during the compilation or timing calculation, the tool displays the message

```
Information: Breaking a timing loop by disabling timing arcs between
  pin 'name1' and pin 'name2'.
```

Timing loops must be disabled ("broken") in order to time the design. After optimization or timing, automatically disabled arcs are restored.

Commands that can initiate automatic breaking of timing loops include the following:

- compile
- check\_timing

- update timing
- report timing
- report\_disable\_timing

After any of these commands completes its tasks, the disabled arcs are enabled. Thus, in a typical session, feedback loops can be disabled and reenabled several times.

Loops can be disabled differently by these commands, which can lead to inconsistent timing results. You can now ensure consistent automatic loop breaking and timing results by setting the use\_auto\_loop\_breaking variable to true (the default value).

When this variable is true, the tool generates a consistency table that preserves the disabled arc information from the first loop breaking. Under most conditions, subsequent loop breaking uses this table to break the loops in exactly the same way, which leads to consistent timing results.

However, any changes to the logic of a design or the constraints clears the consistency table. Also, the table is cleared if you issue any of the following commands:

- set\_disable\_timing object\_list -from pin\_name -to pin\_name
- remove\_disable\_timing object\_list -from pin\_name -to pin\_name
- set case analysis

After the consistency table is cleared, the next command that breaks the timing loops repopulates the table.

The consistency table is written out when you use the write -format ddc -output file name.ddc command.

Additionally, you can save the consistency table by using the write\_script -include {loop\_breaking} command. To obtain information on the disabled arcs, use the report\_timing -loops command. Note that the report\_disable\_timing command reports the automatically disabled arcs under the "L" category.

# **Breaking Feedback Loops Manually**

To report combinational feedback loops, use the report\_timing command. To manually disable timing on parts of a design to break a combinational feedback loop, use the set\_disable\_timing command. Disabled arcs remain disabled until you remove the disable\_timing attribute or use the reset\_design command.

The two types of timing arcs are cell arcs and net arcs. Cell arcs describe the cell's internal pin-to-pin timing and are defined in a technology library cell (component) description. Disabling a cell arc is the same as removing a cell description from the technology library.

Net arcs are implicitly defined by connections between cells. Each driver pin has a net arc to each load pin of a net. Disabling a net arc is the same as breaking the connection between a net driver pin and a load pin.

Use the <code>set\_disable\_timing</code> command to break a timing path at the defined cell or pin arcs. The syntax is

```
set_disable_timing object_list
  [[-from pin_name -to pin_name]
  [-restore]|[-reset_loop_breaking_arcs]]
```

When you use <code>set\_disable\_timing</code> for pins, the pins and their nets are saved during optimization. This might mean that Design Compiler cannot perform some transformations and optimizations and can lower the quality of results.

#### **Example**

```
prompt> set_disable_timing CELL31
prompt> set_disable_timing {U33 U37/A U71/Z}
prompt> set_disable_timing {U17} -from A2 -to ZN
```

To restore previously disabled timing arcs, use the set\_disable\_timing -restore command or the reset design command. For example, enter

```
prompt> set_disable_timing -restore {U3 U71/Z}
```

The report design command lists the cells and pins whose timing arcs are disabled.

The report\_disable\_timing command reports the disabled timing arcs in the design, including those disabled by case analysis, by disabling of false net-arcs, by conditional arcs (arcs that have a when statement defined in the library), by loop breaking, and by using the set\_disable\_timing command.

To produce a report about disabled timing arcs, use the following command:

| Cell or Port | From | То | Sense                  | Flag | Reason |
|--------------|------|----|------------------------|------|--------|
| U1/U1/reg[0] | E    | D  | hold_clk_rise          | С    | D = 0  |
| U1/U1/reg[0] | E    | D  | setup_clk_rise         | С    | D = 0  |
| U1/U1/reg[0] | E    | E  | clock_pulse_width_high | С    | D = 0  |

# 6

# **Back-Annotation**

Back-annotation is the process of reading resistance, capacitance, and delay values from an external file into tool for timing analysis. Using back-annotation, you can more accurately analyze the circuit timing in the tool after each phase of physical design (floorplanning, placement, global routing, and detailed routing).

This chapter has the following sections:

- Back-Annotating Delays and Timing Checks
- Back-Annotating Net Load
- Back-Annotating Net Resistance
- RTL Load Annotation with Wire Load Modeling

# **Back-Annotating Delays and Timing Checks**

For initial static timing analysis, Design Compiler can estimate net delays based on topographical technology or wire load models. Actual delays depend on the physical placement and routing of the cells and nets in the design.

A floorplanner or router can provide more detailed and accurate delay information, which you can provide to Design Compiler for a more accurate analysis. This process is called delay back-annotation. Back-annotated information often is provided in a Standard Delay Format (SDF) file.

You can read SDF back-annotated delay information in these ways:

- Read the delays and timing checks from an SDF file by using the read\_sdf command.
- Annotate delays and timing checks from the command line without using the SDF format by using the set\_annotated\_delay command or set\_annotated\_check command. The set\_annotated\_delay command sets the delay values for specified nets and cells in the current design. The set\_annotated\_check command sets an annotated timing check between two or more pins.

Generally, back-annotating from an SDF file can be significantly faster than using the set\_annotated\_delay and set\_annotated\_check commands.

The set\_annotated\_delay and read\_sdf commands do not perform an exhaustive input validity check; some checking is done during the next timing update. Therefore, to verify that all back-annotation is correct, you can run update\_timing after you have run set\_annotated\_delay Or read\_sdf.

# **Delay Calculations**

Before you use the set\_annotated\_delay and read\_sdf commands, you need to know how the tool reads load delay. Design Compiler uses the following delay definitions:

#### Cell delay

The delay between a state transition on an input pin and the resulting state transition on the output pin of a gate.

#### Load delay

The amount of cell delay introduced by the load of the net being driven, calculated as the loaded cell delay minus what the delay would have been if the net had a total capacitance of zero. Load delay is also known as extra source gate delay.

Connect delay (or net delay)

The delay between the output pin changing state and a subsequent input pin changing state. This is the time-of-flight delay on the net.

Design Compiler correctly interprets SDF files with IOPATH and INTERCONNECT delays as

```
IOPATH = cell delay + load delay
INTERCONNECT = connect delay
```

However, some layout tools define the delays as

```
IOPATH = cell delay - load delay
INTERCONNECT = connect delay + load delay
```

# **Back-Annotating Timing Information from an SDF File**

The read\_sdf command reads leaf cell net and cell delay values from an SDF version v1.0, v2.0, or v2.1 timing file and annotates the values to the current design. This is the command syntax:

```
read_sdf
[-load_delay net | cell]
[-path path_name]
[-min_type sdf_min | sdf_typ | sdf_max]
[-max_type sdf_min | sdf_typ | sdf_max]
[-worst]
[-min_file min_sdf_file_name]
[-max_file max_sdf_file_name]
sdf_file_name
```

Instance-specific pin-to-pin cell and net delays greater than zero are read from the timing file and annotated on the current design.

### **Instance Names**

Instance names in the design must match instance names in the timing file. For example, if the timing file was created from a design using VHDL naming conventions, <code>design\_name</code> must use VHDL naming conventions. To modify design names, use the <code>change\_names</code> command.

### **Cell and Pin Names**

Cell and pin names in the SDF file and the current design must be the same. Object renaming does not occur when an SDF file is being read and loaded. If the names do not match, an error message similar to the following appears:

```
Error: Pin 'B1/C1'/'INC1' could not be found. (SDFN-10)
```

### **DESIGN Field Names**

The DESIGN field in the SDF file must have the same name as the subdesign. If the names do not match, an error message similar to the following appears:

```
Error: The SDF file contains delays for the design 'SYSTEM', they cannot be annotated on design 'BAR'. (SDFN-4)
```

# **Supported SDF Constructs**

Supported constructs are INTERCONNECT and PORT for net delay; IOPATH and COND for cell delay; and SETUP, and HOLD for timing checks. Also, the constructs RECOVERY, REMOVAL, and RETAIN are supported.

The DEVICE construct is parsed but ignored for compilation. (DEVICE is used by VSS.)

### Note:

Design Compiler reads only absolute delays with SDF. Incremental delays are not read.

SDF files are case-sensitive. The DIVIDER (hierarchy divider), TIMESCALE (time unit), and DESIGN (design name) constructs are read from the SDF header.

The hierarchy divider specified in the DIVIDER construct must be either "." or "/".

The read\_sdf command scales the timing data from the SDF time unit, as defined in the TIMESCALE construct, to the unit defined in the library. If no time unit is defined in the library, the default time unit is 1 ns.

If the delay statement in the SDF file has two or more timing expressions, the first two expressions are read as the rise and fall values. If the delay statement has only one timing expression, read sdf assumes that the rise and fall times are the same.

SDF does not support internal pins, so read sdf ignores timing to internal pins.

#### **Examples**

From this delay statement with one expression,

```
(INTERCONNECT A1/Z A2/B (2:3:4))
```

(2:3:4) is read as rise delay and fall delay.

From this delay statement with two expressions,

```
(INTERCONNECT A1/Z A2/B (2:3:4) (1:1:2))
```

(2:3:4) is read as rise delay and (1:1:2) is read as fall delay.

From this delay expression, no rise delay is read and (2:3:4) is read as fall delay.

```
(INTERCONNECT A1/Z A2/B ()(2:3:4))
```

From this delay statement with more than two expressions,

```
(INTERCONNECT A1/Z A2/B (2:3:4) (1:1:2) (4:5:6))
```

(2:3:4) is read as rise delay; (1:1:2) is read as fall delay; and (4:5:6) is not read, as this describes 0-to-Z and 1-to-Z transitions.

Design Compiler does not support all three-states when reading SDF. Only rise (01 and Z1) and fall (10 and Z0) delays are supported; 1Z and 0Z are not supported.

Table 6-1 summarizes the SDF version v2.1 constructs used by the read\_sdf command.

Table 6-1 SDF Constructs Used by read\_sdf

| SDF construct | SDF 2.1 support                                                                                                                                                                                                                           |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DELAYFILE     | Parsed, not used.                                                                                                                                                                                                                         |
| SDFVERSION    | Used. The SDFVERSION entry is mandatory for SDF 1.0 as well as SDF 2.1 files. The Design Compiler SDF reader parses this entry and, depending on the version number read, automatically invokes the SDF 1.0 parser or the SDF 2.1 parser. |
| DESIGN        | Used. The design name must be the name of the current instance.                                                                                                                                                                           |
| DATE          | Parsed, not used.                                                                                                                                                                                                                         |
| VENDOR        | Parsed, not used.                                                                                                                                                                                                                         |
| PROGRAM       | Parsed, not used.                                                                                                                                                                                                                         |
| VERSION       | Parsed, not used.                                                                                                                                                                                                                         |
| DIVIDER       | Used.                                                                                                                                                                                                                                     |
| VOLTAGE       | Parsed, not used.                                                                                                                                                                                                                         |
| PROCESS       | Parsed, not used.                                                                                                                                                                                                                         |
| TEMPERATURE   | Parsed, not used.                                                                                                                                                                                                                         |
| TIMESCALE     | Used.                                                                                                                                                                                                                                     |
| CELL          | Used.                                                                                                                                                                                                                                     |
| CELLTYPE      | Used.                                                                                                                                                                                                                                     |

Table 6-1 SDF Constructs Used by read\_sdf (Continued)

| SDF construct   | SDF 2.1 support                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORRELATION     | Parsed, not used.                                                                                                                                                                                                                                                                                                                                                                                                |
| INSTANCE        | Used.                                                                                                                                                                                                                                                                                                                                                                                                            |
| DELAY           | Used.                                                                                                                                                                                                                                                                                                                                                                                                            |
| TIMINGCHECK     | Used.                                                                                                                                                                                                                                                                                                                                                                                                            |
| ABSOLUTE        | Used.                                                                                                                                                                                                                                                                                                                                                                                                            |
| INCREMENT       | Not used.                                                                                                                                                                                                                                                                                                                                                                                                        |
| PATHPULSE       | Parsed, not used.                                                                                                                                                                                                                                                                                                                                                                                                |
| GLOBALPATHPULSE | Parsed, not used.                                                                                                                                                                                                                                                                                                                                                                                                |
| IOPATH          | Edge specification on input ports is ignored.                                                                                                                                                                                                                                                                                                                                                                    |
|                 | 12 values are read; 6 values are used (combinational, enable and disable for rise and fall).                                                                                                                                                                                                                                                                                                                     |
|                 | The only mapping done is in the case of a single-valued SDF delay entry. This single value gets mapped to both the 01 (rise) and 10 (fall) timing arcs.                                                                                                                                                                                                                                                          |
|                 | If the library cell contains arrayed ports, the SDF file must contain bit-<br>blasted entries. A range specification in the SDF file is not supported. The<br>SDF file cannot reference an unindexed composite port name.                                                                                                                                                                                        |
|                 | In case of multiple annotations to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when the <code>-worst</code> option is specified. See the <code>read_sdf</code> man page.                                                                                                                                                             |
|                 | If the library cell has conditional delays, the SDF IOPATH entry automatically applies to all conditional paths specified in the library cell.                                                                                                                                                                                                                                                                   |
|                 | IOPATH delays between two output ports are supported although SDF does not allow output to output IOPATH. If the SDF file contains delays from input to output but there is no library timing arc between the two pins, a warning appears and the IOPATH is ignored.                                                                                                                                             |
| IOPATH          | Conditional expressions are ignored by Design Compiler. In case of multiple conditions to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when the <code>-worst</code> option is specified. In case of multiple annotations to the same delay site, the delay value selected can be specified through the SDFPOLICY setup file variable. |

Table 6-1 SDF Constructs Used by read\_sdf (Continued)

| SDF construct           | SDF 2.1 support                                                                                                                                                                                                                                      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PORT                    | Delays are annotated between all pins in the fanin and the input port.                                                                                                                                                                               |
|                         | If the SDF file contains INTERCONNECT to the same input port, the interconnect value overrides the port value.                                                                                                                                       |
|                         | In case of multiple annotations to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when the <code>-worst</code> option is specified. See the <code>read_sdf</code> man page. |
|                         | 12 values parsed; 2 values supported: 01, 10.                                                                                                                                                                                                        |
|                         | The only mapping done is in the case of a single valued SDF delay entry. This single value gets mapped to both the 01 (rise) and 10 (fall) of the timing arc.                                                                                        |
|                         | If the library cell contains arrayed ports, the SDF file must contain bit-<br>blasted entries. A range specification in the SDF file is not supported. The<br>SDF file cannot reference an unindexed composite port name.                            |
|                         | The input port must be a leaf-cell pin. A warning message appears and the PORT is ignored if the input port is a nonleaf pin.                                                                                                                        |
| INTERCONNECT            | Net delays are annotated between the two given pins.                                                                                                                                                                                                 |
|                         | If the SDF file contains PORT to the same input port, the interconnect value overrides the port value.                                                                                                                                               |
|                         | In case of multiple annotations to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when the <code>-worst</code> option is specified. See the <code>read_sdf</code> man page. |
|                         | 12 values parsed; 2 values supported: 01, 10.                                                                                                                                                                                                        |
|                         | The only mapping done is in the case of a single valued SDF delay entry. This single value gets mapped to both the 01 (rise) and 10 (fall) of the timing arc.                                                                                        |
|                         | If the library cell contains arrayed ports, the SDF file must contain bit-<br>blasted entries. A range specification in the SDF file is not supported. The<br>SDF file cannot reference an unindexed composite port name.                            |
|                         | Both pins must be leaf-cell pins. A warning message appears and the INTERCONNECT is ignored if either pin is a nonleaf pin.                                                                                                                          |
| NETDELAY                | Parsed, not used.                                                                                                                                                                                                                                    |
| DEVICE                  | Parsed, ignored.                                                                                                                                                                                                                                     |
| conditional constraints | Parsed, not supported.                                                                                                                                                                                                                               |

Table 6-1 SDF Constructs Used by read\_sdf (Continued)

| SDF construct            | SDF 2.1 support                                                                                                                                                                                                                                     |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SETUP                    | Edge specification on both ports is supported.                                                                                                                                                                                                      |
|                          | In case of multiple annotations to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when you specify the <code>-worst</code> option. See the <code>read_sdf</code> man page. |
| HOLD                     | Edge specification on both ports is supported.                                                                                                                                                                                                      |
|                          | In case of multiple annotations to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when you specify the <code>-worst</code> option. See the <code>read_sdf</code> man page. |
| SETUPHOLD                | Edge specification on both ports is supported.                                                                                                                                                                                                      |
|                          | In case of multiple annotations to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when you specify the <code>-worst</code> option. See the <code>read_sdf</code> man page. |
| RECOVERY                 | Edge specification on both ports is supported.                                                                                                                                                                                                      |
|                          | In case of multiple annotations to the same delay site, the delay value selected is the last value specified in the SDF file. The worst value is annotated when you specify the <code>-worst</code> option. See the <code>read_sdf</code> man page. |
| REMOVAL                  | You can specify removal timing checks with the HOLD statement.                                                                                                                                                                                      |
| SKEW                     | Ignored.                                                                                                                                                                                                                                            |
| WIDTH                    | Ignored.                                                                                                                                                                                                                                            |
| PERIOD                   | Ignored.                                                                                                                                                                                                                                            |
| NOCHANGE                 | Ignored.                                                                                                                                                                                                                                            |
| PATHCONSTRAINT           | Ignored.                                                                                                                                                                                                                                            |
| SUM                      | Ignored.                                                                                                                                                                                                                                            |
| DIFF                     | Ignored.                                                                                                                                                                                                                                            |
| SKEWCONSTRAINT           | Ignored.                                                                                                                                                                                                                                            |
| C and C++ style comments | Supported.                                                                                                                                                                                                                                          |

# **Back-Annotating Timing From a Subdesign Timing File**

When you specify the <code>-path</code> option, the <code>read\_sdf</code> command annotates the current design with information from a timing file created from a subdesign of the current design. When you specify a subdesign, you cannot use the net delays to the ports of the subdesign to annotate the current design.

# **Back-Annotating Load Delay**

Load delay is the contribution to the overall cell propagation delay caused by capacitive loading. Load delays can be written out as part of the cell delay or as part of the net delay. The default assumes that the load delays are included in the cell delays in the timing file being read. Some delay calculators consider load delay to be part of the net delay, and others consider it part of the cell delay. Use the read\_sdf -load\_delay option to specify whether the load delay is part of the net delay or part of the cell delay.

# **Back-Annotating for Worst Timing Delay**

Use the remove\_annotated\_delay -all command and the remove\_annotated\_check command before using the read\_sdf -worst command to annotate the worst timing delay and timing checks of all timing conditions for each pin-to-pin annotation.

This behavior does not depend on the type of timing arc being read (whether the arc is a SETUP arc or a HOLD arc). This is particularly important because worst might lead to the belief that for HOLD timing arcs minimum values will be read. The correct behavior is one where all the values read from are either minimum, typical, or maximum, regardless of the type of timing arc.

# **Back-Annotating Timing Checks**

Setup, hold, recovery, and removal timing checks, when present in the timing file, are used to annotate the current design. The SDF constructs are

| For this check | The SDF Construct is |
|----------------|----------------------|
| setup and hold | SETUP and HOLD       |
| recovery       | RECOVERY             |
| removal        | REMOVAL              |

# **Back-Annotating for Conditional Arc Cell Delay**

Delays and timing checks specified in an SDF file can be conditional. The SDF condition is usually an expression based on the value of some inputs or combination of inputs of the annotated cell. The way the tool annotates these conditional delays depends on whether the technology library specifies conditional arcs.

- If the technology library contains conditional arcs, the corresponding conditional delays specified in the SDF file are annotated on these arcs. The condition strings specified in the technology library and the SDF file must exactly match.
- If the technology library does not contain conditional arcs, the maximum delay or minimum delay, selected from all the SDF conditional arc delays, is annotated.

If your technology library does contain state-dependent delays, using the conditional arc delays from an SDF file is recommended because a more accurate timing analysis can result. Also, if you do an incremental compile after annotating these delays, the annotated conditional delays persist for those cells that are not replaced or removed during optimization. Because these annotated delays usually provide more accurate delay estimations, you can expect improved timing and quality of results.

#### Note:

When carrying out a timing analysis or incremental compile, you can use the set\_case\_analysis command to select a given condition on an input pin.

For example, if the delay for the timing arc from input pin A to output pin Z of cell U1 depends on the value (1 or 0) at input pin B and you want the A-to-Z delay value associated with 0 at pin B, enter

```
prompt> set_case_analysis 0 [get_pins U1/B]
```

# **Reading SDF Instance Names**

The variable <code>sdfin\_top\_instance\_name</code> defines the name prepended to all instance names in the SDF file. This variable is set, by default, to an empty string. The tool assumes that cell instance names do not already contain prepended names. If cell instance names have prepended names, set <code>sdfin\_top\_instance\_name</code> to the prepended name.

For example, if the SDF file contains the following:

```
(DESIGN "fifo")
(DIVIDER .)
(CELL
  (CELLTYPE "fifo")
  (INSTANCE stim\.cell1)
```

```
(CELL
  (CELLTYPE "AND2")
  (INSTANCE stim\.cell1.U1)
)
```

set the sdfin top instance name variable to stim.cell1 before reading the SDF file.

#### Note:

The read\_sdf command does not support INSTANCE \*. You must define each instance timing separately.

### **Back-Annotation Order of Precedence**

When pin-to-pin timing and resistance and capacitance values are back-annotated, timing information is obtained from the following sources in the following order of precedence:

- 1. SDF pin-to-pin values
  - The delay information in the SDF is the most accurate.
  - The timing reports have an asterisk (\*) on timing arcs read from an SDF file. Note that annotated conditional timing arcs are reported.
  - The SDF data is sufficient if all the timing arcs in the design have a value backannotated from an SDF file and the design meets timing.
- 2. Annotated resistance and capacitance values on a net
  - Because lumped resistance and capacitance values are considered, the RC delay numbers are pessimistic and not as accurate as SDF pin-to-pin delays.
  - For the following reasons, you need the resistance and capacitance values:

The technology or place and route library does not contain certain arcs. For example, the technology library has timing arcs for CLK -> QB and QB -> Q, but the technology library has a CLK -> Q arc. The tool requires the back-annotated resistance and capacitance values in order to compute the timing.

Timing is not met, by a small margin, and you want to do in-place optimization. In such a case, you can use the resistance and capacitance values to compute timing with the new cells.

Large timing violations exist, and you want to recompile but with accurate wire load models (using <code>create\_wire\_load</code>). The tool uses the capacitance values when it creates the wire load models.

Missing resistance or capacitance value is extracted from the wire load model.

#### Wire load models

- Wire load models are based on historical data; they can be the least accurate.
- Both resistance and capacitance values are generated, then the delay is calculated.

# **Examples**

This section presents examples on using the read\_sdf command.

### **Example 1**

To read the SDF file cir.sdf for the design cir, enter

```
prompt> current_design cir
prompt> read_sdf cir.sdf
```

### Example 2

To read maximum and minimum delay values from two separate SDF files, enter

```
prompt> read_sdf -min_file min.sdf -max_file max.sdf
```

#### Example 3

To read timing information of instance u1 of design MULT16 from the disk file mult16\_u1.sdf and have the timing annotated on the design MY\_DESIGN, enter

```
prompt> current_design MY_DESIGN
prompt> read_sdf -load_delay net -path u1 mult16_u1.sdf
```

# Writing an SDF File

You might want to write out the back-annotated delay information so that it can be used for gate-level simulation or some other purpose. You can use the <code>write\_sdf</code> command to write the delay information in SDF v1.0 or v2.1 format. The default output format is v2.1.

For example, to write an SDF file, enter

```
prompt> write_sdf -version 2.1 mult16.sdf
```

# **Annotating Delays and Timing Checks From The Command Line**

You can annotate delays and timing checks from the command line without using the SDF format by using the <code>set\_annotated\_delay</code> command or <code>set\_annotated\_check</code> command as described in the following sections.

### **Defining Net and Cell Delays**

The set\_annotated\_delay command sets actual net and cell delay values in the current design or the net delay between two or more pins or ports on the same net.

To verify that the back-annotation done by set\_annotated\_delay is correct, run update\_timing. If the current design is hierarchical, you must link it, using link -all, before using set\_annotated\_delay.

Load delay is the portion of cell delay caused by the capacitive load of the net being driven. Some delay calculators consider load delay part of the net delay and others consider it part of the cell delay.

- If your annotated delay value assumes that load delay is part of the cell delay, use load\_delay cell.
- If your delay value assumes that load delay is included in the net delay, use -load\_delay net.

By default, load delays are assumed to be in cell delays and appear in report\_timing path listings.

The specified delay value overrides the internally estimated cell and net delay value. If the specified pins are not in the same cell or on the same net, an error message appears when the timing is updated and <code>delay\_value</code> is discarded for those pins. <code>set\_annotated\_delay</code> can be used for pins at lower levels of the design hierarchy. Pins are specified as <code>INSTANCE1/INSTANCE2/PIN NAME</code>.

To list annotated delay values, use the report\_annotated\_delay command.

To remove the annotated cell or net delay values from a design, use remove annotated delay of reset design.

#### The syntax is

```
set_annotated_delay
  -net|-cell
  [-load_delay net | cell]
  [-rise | -fall]
  [-min] [-max]
  -from from_list -to to_list
  [-worst]
```

#### Note:

For more information, see the set\_annotated\_delay man page.

### **Example 1**



For this circuit, to annotate a net delay of 4 on the net connected to cell output pin M/Z, enter

```
prompt> set annotated delay -net 4 -from M/Z
```

The net delay between M/Z and U/A is 4, and the net delay between M/Z and V/B is also 4.

To annotate a net delay of 5 on the net connected to cell input pin U/A, enter

```
prompt> set_annotated_delay -net 5 -to U/A
```

The net delay between M/Z and U/A is 5, and the net delay between M/Z and V/B is not changed.

To annotate a net delay of 6 between cell output pin M/Z and cell input pin U/A, enter

```
prompt> set annotated delay -net 6 -from U/Z -to U/A
```

The net delay between M/Z and u/A is 6, and the net delay between M/Z and V/B is not changed.

Defining different net delays for pins on the same net causes ambiguity, for example, setting delay on a net connecting the output pin Z of cell M to the input pin A of cell U.

```
prompt> set_annotated_delay -net -rise 4 -from m/Z
prompt> set_annotated_delay -net -rise 5 -to u/A
```

In this case, when timing is updated, a warning message appears.

```
(Warning) Overwriting the rise delay between pin 'M/Z' and pin 'U/A' with (4). (OPT-835)
```

### Example 2

To annotate a rise net delay of 12.3 units for minimum delay analysis between the output pins of two circuits, enter

### **Defining Timing Check Values Between Pins**

The set\_annotated\_check command sets an annotated timing check between two or more pins.

Use set\_annotated\_check after place and route for technologies in which the timing check value varies on different instances and the library timing check values do not provide sufficient accuracy.

If the design is not already linked, <code>set\_annotated\_check</code> links it automatically. You can use <code>set\_annotated\_check</code> for the pins at lower levels of the design hierarchy. Specify pins as <code>INSTANCE1/INSTANCE2/PIN\_NAME</code>.

To list annotated timing check values, use report\_annotated\_check.

To see the effect of set\_annotated\_check for a specific instance, use report\_timing.

#### The syntax is

```
set_annotated_check check_value
  -from from_pins -to to_pins
  -setup | -hold | -removal | -recovery |
  -nochange_high | -nochange_low
  [-rise -fall]
  [-clock clock_check]
  [-worst]
```

#### Note:

For more information, see the set annotated check man page.

#### Example

To annotate a setup time of 2.1 units between clock pin CP of cell instance u1/ff12 and data pin D of the same cell instance, enter

```
prompt> set_annotated_check -setup 2.1 -from u1/ff12/CP -to u1/ff12/D
```

To remove annotated timing check values from a design, use remove\_annotated\_check or reset\_design.

# **Reporting Annotated Values and Checks**

Reports provide information about the implementation of your design. The tool provides commands to report the following:

- Load and resistance values
- Annotated delay values
- Annotated timing checks
- Back-annotated values command summary

### **Reporting Load and Resistance Values**

The report\_net command displays the net load and resistance values. Annotated values appear in the Attributes column with a c or an r.

Attributes such as <code>dont\_touch</code> are displayed for each net. The <code>dont\_touch</code> attribute can be present on a net as an implicit attribute. This can happen when the <code>set\_dont\_touch\_network</code> command is used. All nets in the transitive fanout of a port are affected, but the <code>dont\_touch</code> cannot be removed independently on these nets.

### The syntax is

```
report_net
  [-nosplit] [-noflat] [-transition_times]
  [-only_physical [-verbose]]
  [-cell_degradation] [-min] [-connections [-verbose]]
  [-physical [-verbose]][net_list]
  [-significant_digits [digits]]
  [-max_toggle_rate]
```

#### Note:

For more information, see the report net man page.

### **Example**

```
prompt> report_net
Information: Updating design information... (UID-85)
...
Attributes:
    d - dont_touch
    c - annotated capacitance
    r - annotated resistance
Net         Fanout Fanin Load Resistance Pins Attributes
...
cell57/n16    1    1   1.00   100.00   2   r
cell57/n17    3    1   3.17   100.00   4   c, r
cell57/n18    2    1   5.36   100.00   3   c, r
```

```
Total 13 nets 25 13 31.53 1300.00 38

Maximum 4 1 8.53 100.00 5

Average 1.92 1.00 2.43 100.00 3.22
```

You can also display back-annotated values by using the report\_attribute -net command. The load attribute is used for back-annotated capacitance. The ba net resistance attribute is used for back-annotated resistance.

## **Reporting Annotated Delay Values**

The report\_annotated\_delay command displays back-annotated data for cells or nets.

The delay values reported are the resulting cell and net delays used in report\_timing and might not be your annotated values if delays were annotated with the -load\_delay net option of the read\_sdf command or the set\_annotated\_delay command.

### The syntax is

```
report_annotated_delay [-cell] [-net] [-summary] [-nosplit]
```

### **Example 1**

This example shows that the counter design has only one cell delay annotated between pin CO/A and pin CO/Z.

### Example 2

This example shows that the counter design has one net with annotated values. Net h has a lumped capacitance (50.00) and a lumped resistance (200.00). A net delay of 200 is annotated between two of the pins on net h. Net h has no annotated timing between pin ffc/QN and pin r/B.

prompt> report\_annotated\_delay -net

| Net | Name   | From | То     | Rise | Fall | Load  | Res.   |
|-----|--------|------|--------|------|------|-------|--------|
|     | ffc/QN | w/A  | 200.00 |      | 0.00 | 50.00 | 200.00 |
| h   | ffc/QN | m/B  | 200.00 | 20   | 0.00 | 50.00 | 200.00 |
| h   | ffc/QN | r/B  |        |      |      | 50.00 | 200.00 |

### **Reporting Annotated Timing Checks**

The report\_annotated\_check command displays back-annotated timing checks on the current design, including the data rise and fall and the clock edge.

To list annotated delays, use report\_annotated\_delay (described earlier in this chapter).

### The syntax is

```
report_annotated_check [-nosplit]
-nosplit
```

Disables line splitting when information exceeds its column's width.

### Example

```
prompt> report_annotated_check
...*
```

| Cell Name | From | То  | Rise | Fall | Timing Check          |
|-----------|------|-----|------|------|-----------------------|
| U1        | С    | cdn | 0.16 | 0.00 | recovery_clock_rising |
| U1        | cn   | cdn | 0.33 | 0.00 | removal_clock_rising  |

Post-layout optimization and in-place optimization remove the annotated timing checks when they become invalid (when a net connected to the cell with timing checks is modified).

### **Reporting Back-Annotated Values Command Summary**

Table 6-2 summarizes the commands for displaying back-annotated values in the current design.

Table 6-2 Summary of Commands for Reporting Back-Annotated Values

| To report this                                                                          | Use this               |
|-----------------------------------------------------------------------------------------|------------------------|
| Timing information for current instance                                                 | report_timing          |
| Back-annotated data for cells or nets                                                   | report_annotated_delay |
| Annotated timing checks                                                                 | report_annotated_check |
| Net load and resistance values for current instance or current design                   | report_net             |
| Attributes and their values associated with a cell, net, pin, port, instance, or design | report_attribute       |

# **Removing Back-Annotated Values**

To remove delays read and annotated with <code>read\_sdf</code>, use <code>reset\_design</code> or <code>remove\_annotated\_delay</code>. The <code>compile</code> command also removes annotated delays (except delays in cells and nets that have the <code>dont\_touch</code> attribute). To remove timing checks annotated with <code>read\_sdf</code>, use the <code>remove\_annotated\_check</code> command. This section describes the following topics:

- · Remove annotated delay values
- Remove annotated timing checks between specified pins
- Remove annotated resistance and capacitance values
- Remove back-annotated values command summary

### **Removing Annotated Delay Values**

The remove\_annotated\_delay command removes annotated delay values between two pins or all annotated delay values in the same cell.

Both rise and fall annotated delays are removed. remove\_annotated\_delay can be used for pins at lower levels of the design hierarchy. These pins are specified as INSTANCE1/INSTANCE2/PIN NAME.

If the current design is hierarchical, link the design by using link -all before using remove\_annotated\_delay.

Use the -from and -to options in the same manner you used them to set annotated values.

### For example,

| To remove this                                            | Use this                         |
|-----------------------------------------------------------|----------------------------------|
| An annotated delay set with set_annotated_delay -from     | remove_annotated_delay -from     |
| An annotated delay set with set_annotated_delay -to       | remove_annotated_delay -to       |
| An annotated delay set with set_annotated_delay -from -to | remove_annotated_delay -from -to |

A timing arc must exist between the pins in *from\_list* and the pins in *to\_list*, or Design Compiler will not remove any annotated delay and a warning will appear:

```
prompt> remove_annotated_delay -from ffd/Q -to m/B Warning: There is no timing arc between pin `ffd/Q' and pin ^m/B'. (OPT-834)
```

When the tool removes delays, informational messages appear:

```
Information: Removing delays annotated to pin `w/A'. (OPT-831) Information: Removing annotated delays from pin `ffc/QN' to pin `w/A'. (OPT-830)
```

If no annotated delay values exist on a net or cell specified in the remove\_annotated\_delay command, no warning or informational message appears.

### The syntax is

```
remove_annotated_delay -all | -from pin_list | -to pin_list
```

#### Note:

For more information, see the remove annotated delay man page.

### **Examples**

To remove a delay value from a net annotated with the command

```
prompt> set_annotated_delay -net delay_value -from ffd/CP -to m/B
enter
```

```
prompt> remove_annotated_delay delay_value -from ffd/CP -to m/B
```

To remove all annotated delays from the current design, enter

```
prompt> remove_annotated_delay -all
Information: Removing all annotated delays from design
'counter'. (OPT-804)
```

# **Removing Annotated Timing Checks Between Specific Pins**

The remove\_annotated\_check command removes annotated timing check information between specific pins.

Removes annotated timing checks between the specified pins. Data rise and fall and clock rise and fall annotated checks are removed by default. The remove\_annotated\_check command can be used for pins at lower levels of the design hierarchy. These pins are specified as INSTANCE1/INSTANCE2/PIN NAME.

If the design is not already linked, remove\_annotated\_check links it automatically.

The remove\_annotated\_check command removes annotated timing checks set by set\_annotated\_check and removes setup, hold, recovery, or removal annotated timing checks set by read\_sdf.

#### The syntax is

#### Note:

For more information, see the remove\_annotated\_check man page.

#### Example

To remove an annotated setup check between pins u1/u2/CP and u1/u2/D, enter

```
prompt> remove_annotated_check -setup -from u1/u2/CP -to u1/u2/D
```

To specify a rising or falling clock edge, enter the following command sequence:

```
prompt> remove_annotated_check -clock rise \
    -from [get_pins "U1/cn"] -to [get_pins "U1/sdn"]
prompt> remove_annotated_check -clock fall \
    -from [get_pins "U1/cn"] -to [get_pins "U1/sdn"]
```

You can use the reset\_design command to remove back-annotated values in the design, but reset\_design removes all attributes and constraints from the design.

# **Removing Annotated Resistance or Capacitance Values**

You can also use the remove\_attribute command to remove resistance or capacitance back-annotation from specified nets in the design.

- To remove annotated capacitance, remove the load attribute.
- To remove annotated resistance, remove the attribute ba net resistance.

#### **Examples**

To remove the back-annotated resistance on net U1/U2/Net3, enter the following command:

```
prompt> remove_attribute [get_nets U1/U2/Net3]ba_net_resistance
```

To remove all annotated capacitances on all nets, enter the following command:

```
prompt> remove_attribute [get_nets *) load
```

To remove the annotated capacitance on net foo, enter the following command:

```
prompt> remove_attribute [get_nets "foo"] load
```

### **Removing Back-Annotated Values Command Summary**

Table 6-3 summarizes the commands for removing back-annotated values.

Table 6-3 Summary of Commands for Removing Back-Annotated Values

| To do this                                                                                  | Use this                           |
|---------------------------------------------------------------------------------------------|------------------------------------|
| Remove annotated values between two pins or all annotated values from the current design    | remove_annotated_delay             |
| Remove annotated timing checks between specific pins                                        | remove_annotated_check             |
| Remove annotated resistance                                                                 | remove_attribute load              |
| Remove annotated capacitance                                                                | remove_attribute ba_net_resistance |
| Remove all user-specified objects and attributes, except those defined using set_attribute. | reset_design                       |

# **Back-Annotating Net Load**

To replace estimated wire capacitance values with actual values determined by an external tool, create a file containing one  $set_load$  command for each net, as in the following example:

```
      set_load
      2.739
      INPUT7

      set_load
      2.101
      net204

      set_load
      3.433
      cel133/n28

      set_load
      1.007
      FF21_Q
```

You then include the file as a Design Compiler command script. In some systems, your place and route tool can produce this file.

Use the following procedure to replace the estimated net loads with actual values:

1. Edit the file generated by your place and route tool to use the following line format:

```
set_load load_value net_name [-subtract_pin_load]
```

#### For example,

```
set_load 0.052 cell109/n29
set_load 0.052 net251
set_load 0.052 net266
set_load 0.2152 net798
set_load 0.1052 net800
set_load 0.1052 net802
set_load 0.3052 net803
set_load 0.052 net804
```

2. Run the script file by using the source command.

```
prompt> source load_file_name
```

3. Display the resulting annotated nets with the report\_net, report\_attribute, or report annotated delay command.

The tool calculates total load for nets as follows:

```
total_net_load = pin_capacitance + wire_load
```

Pin capacitance it the sum of all capacitance values of all pins on a net, as defined in the technology library description. Wire load is the wire capacitance for a given net, usually estimated by Design Compiler from the wire load model.

You can back-annotate the wire\_load parameter of the total net load equation by using the set load command.

The syntax for the set load command is:

```
set_load
  load_value object_list
  [-min][-max]
  [-subtract_pin_load]
  [[-pin_load][-wire_load]]
```

For more information, see the set\_load man page.

#### Example

```
prompt> set_load 6.53 cell57/n15
Performing set_load on net 'cell57/n15'.
```

Sometimes physical design tools produce capacitance reports that associate wire load with the name of a pin connected to the net. Use the all\_connected command with set\_load to identify the net to which the pin is connected, and set a load value on it. For example,

```
prompt> set_load 6.53 [all_connected cell57/inv2/Z]
Performing set_load on net 'cell57/n15'.
```

CPU overhead is involved in processing the previous command. A design with 100,000 nets can take a long time to process.

Sometimes a net name equals a port name. In such cases, use the following command:

```
prompt> set_load 6.53 [get_nets cel157/n15]
```

The all\_connected, find, and get\_nets commands are described in *Design Compiler User Guide*.

# **Back-Annotating Net Resistance**

The set\_resistance command defines the wire resistance for nets in an optimized design. This command overwrites the Design Compiler internally estimated net resistance values.

Resistance is estimated on the basis of the tree type used in the current operating conditions.

- For a balanced tree, the resistance annotated is assumed to be balanced across all loads. The resistance (R) from the driver to each of the N loads is R/N.
- For a worst-case tree, the resistance from the driver to each load is assumed to be R.
- For a best-case tree, resistance is ignored (not used). The net delay is zero, resulting in optimistic delay values.

The syntax is

```
set_resistance
  resistance_value
[-min][-max]
  object_list
```

For more information, see the set\_resistance man page.

#### **Examples**

To set a resistance of 200 units on nets a and b, enter

```
prompt> set_resistance 200 {a b}
```

To set a resistance of 300 units on the net U1/U2/Net3, enter

```
prompt> set_resistance 300 U1/U2/Net3
```

Sometimes physical design tools produce resistance reports that associate values with the name of a pin connected to the net. Use the all\_connected command with set resistance to identify the net to which the pin is connected. For example,

```
prompt> set_resistance 6.53 [all_connected(cell57/inv2/Z]
```

CPU overhead is involved in processing the previous command. A design with 100,000 nets can take a long time to process. In such cases, use the <code>get\_nets</code> command. For example,

```
prompt> set_resistance 6.53 [get_nets cel157/n15]
```

Because the set\_load and set\_resistance commands verify the design links each time you run them, you can significantly reduce the runtime of a script if you link the design and disable the autolink feature at the beginning of the script. After the script has finished running, re-enable the autolink feature.

For example, enter the following command sequence:

```
prompt> set auto_link_disable true
prompt> source load_res.file
prompt> set auto_link_disable false
```

By default, the dctcl source command does not echo the script commands to the screen. When you do not echo the script commands to the screen, the script runs faster and you can easily find messages about unfound nets in the output list.

# **Back-Annotating Detailed Parasitics**

You can read net parasitic data generated by an external tool so that the timing analyzer can calculate delays from that data. Design Compiler can estimate wire delays by using wire load models or topographical technology. However, if you have detailed parasitic data available from an external tool, Design Compiler can use that information to accurately calculate net delays.

This is the read\_parasitics command syntax in Design Compiler:

```
read_parasitics
[-syntax_only]
[-elmore | -arnoldi]
[-increment]
[-pin_cap_included]
[-net_cap_only]
[-complete_with zero | wlm]
[-path path_name]
[-strip_path path_name]
[-quiet | -verbose]
[-dont_write_to_db]
[file_list]
```

This command can read parasitic data in SPEF, DSPF, or RSPF format.

The <code>-elmore</code> option makes the tool create an RC tree and back-annotate delay estimated from the parasitic data based on the Elmore delay model. The <code>-arnoldi</code> option does the same, but it uses the Arnoldi delay model instead. If neither <code>-elmore</code> nor <code>-arnoldi</code> is specified, the RC tree is created without estimating or back-annotating delays.

If you have multiple parasitic information, add either <code>-elmore</code> or <code>-arnoldi</code> to the last <code>read\_parasitics</code> only, as shown in the following script example, to save runtime.

```
current_design A
read_parasitics A1.spef
read_parasitics A2.spef
read parasitics A3.spef -arnoldi
```

The read\_parasitics command options of Design Compiler and IC Compiler are somewhat different. This is the syntax in IC Compiler:

```
read_parasitics
[-format SPEF | SBPF]
[-syntax_only]
[-max_file max_file_name
[-min_file min_file_name]]
[-keep_capacitive_coupling]
[-triplet_type min | typ | max]
[-eco]
[-ilm_context]
[file_list]
```

This command can read parasitic data in SPEF or SBPF format. IC Compiler uses its internal delay calculator to determine the delays resulting from the net parasitics. You can optionally read two files, one for minimum and one for maximum operating conditions.

For more information, see the read\_parasitics man page for the applicable tool.

To remove some or all annotated delays, use the remove\_annotated\_delay command.

### RTL Load Annotation with Wire Load Modeling

Design Compiler can models nets by using wire load models. Wire load models can be inaccurate for modeling very long nets. For interblock top-level nets this inaccuracy can be large. You can use the <code>set\_load</code> command during reoptimize-design to annotate a load value on a net. During a compile, however, the annotated load is lost because the compile does not retain this information. Use RTL load annotation to retain this information.

With RTL load annotation, you can specify more accurate delays for long nets in the design, resulting in more realistic interconnect delays. RTL load annotation enables you to annotate a load value larger than the load suggested by wire load models on top-level interblock nets in the design.

The RTL load annotation is retained throughout the synthesis process and is used during structuring, mapping, and optimization. The net with the annotated load can undergo optimization and still retain the annotated load value. After placement is completed in the design cycle, the annotated loads can be replaced by more accurate models. Nets without any annotation or with optimized logic continue to use statistical wire load models for optimization.

#### **RTL Load Connections**

The RTL load annotation overrides the statistical wire loads for selected long nets during the compile. The annotated loads work with unmapped logic and DesignWare components. They can be used during structuring, mapping, and placement-independent optimization.

The value to be annotated can be obtained from

- Initial estimates
- Initial place and route
- Initial floorplan

The RTL load can be annotated on

- Ports and pins
- Nets between hierarchical ports and pins
- Nets between pins of dont touch, size only, or black box cells

The annotated load is retained on the top level and on hierarchical ports and pins of dont\_touch, size\_only, or black\_box gates. The RTL load annotation is on the net but stored on the pins. An annotated net must have at least one RTL load connection. See Figure 6-1 on page 6-28.

Figure 6-1 Setting an RTL Load



### **Using RTL Load Annotation**

To annotate the load and resistance values on the nets, do the following steps:

- 1. Read in a design that has long nets. The design can be in RTL or .ddc format.
- 2. To annotate a load or resistance value on a net, use the set\_rtl\_load command. If you are annotating a value on a net, be sure the net has at least one RTL load connection.

The set\_rtl\_load command sets an RTL load value for capacitance and resistance on pins, ports, and nets. The command sets total capacitance (C) for a net and distributes it equally among RTL load connections. The resistance value (R) is applied equally to all connections.

```
prompt> set_rtl_load my_net -cap 2 -res 0.5
```

Figure 6-2 shows how the capacitance value is distributed equally.

Figure 6-2 Calculating With RTL Loads





3. To see if the annotated value has been applied on the cell or net, use one of the following commands:

For a report on the RTL load values on cells, use

prompt> report\_cell -connections -verbose

For a report the RTL load values on nets, use

prompt> report\_net -connections -verbose

To write RTL load commands for the current design to a script, use the write\_rtl\_load command.

- 4. To remove the annotated load and resistance, use the remove\_rtl\_load command or the reset\_design command.
  - To remove an RTL load value for capacitance and resistance from pins, ports, and nets, use the following syntax:

remove\_rtl\_load [-all] [pin\_net\_list]

 To remove all user-specified objects and attributes from the current design, use prompt> reset\_design

#### **Default Resistance Values**

Specifying the resistance values directly to  $set_rtl_load$  is not required. Instead, you can calculate resistance value as a constant factor times capacitance. You choose the factor by setting the  $rtl_load_resistance_factor$  variable. For instance, if the RTL load capacitance of a pin is set to 4, the RTL load resistance is not set, and  $rtl_load_resistance_factor$  is set to 0.5, a resistance of 2 is used. The factor is applied to each annotated pin of a net individually, not to the net's capacitance as a whole. Default library units are used throughout. The default value of  $rtl_load_resistance_factor$  is zero.

### **RTL Load Buffering**

When you are using RTL load buffering, remember the following points:

- If buffers are added, the annotated load remains attached to the RTL load annotated pins.
- Location and placement information is not taken into account during buffering.
- RTL load buffering is intended for early synthesis approximation only.

# **Extracting RTL Loads From Placement**

The calculate\_rtl\_load command can convert back-annotated layout information from set\_load for nets, read\_sdf, and set\_annotated delay to rtl\_load values, which can be used for RTL level optimization.

```
calculate_rtl_load [-capacitance] [-delay] pin_net_list
```

This command calculates RTL load values based on layout-based annotation.

# Extraction of set\_rtl\_load

RTL loads are extracted only on nets and pins that are specified by you. The calculation of the set\_rtl\_load are as follows:

 Capacitance from wire load modeling for random logic blocks is subtracted from the set\_load values.

- The remaining capacitance from set\_load are distributed equally to user-specified pins.
- Resistance values are generated to try to match the timing delays from SDF.

See Figure 6-3 for more information about RTL load extraction.

Figure 6-3 Extracting an RTL Load



The calculate\_rtl\_load command converts back-annotated layout information from set\_load, SDF, and annotated delay to rtl\_load values for RTL optimization.

7

# **Timing Reports**

Design Compiler and IC Compiler can generate a wide range of reports that provide information about the design contents and analysis results. This chapter describes the most commonly used reports.

- Reporting Commands
- check\_timing Command
- report\_constraint Command
- report\_timing Command
- report\_delay\_calculation Command
- get\_timing\_paths Command
- report\_clock\_timing Command

## **Reporting Commands**

The reporting commands <code>check\_timing</code>, <code>report\_constraint</code>, <code>report\_timing</code>, and <code>report\_clock\_timing</code> are commonly used in synthesis and physical implementation flows to get information about the timing of the design.

The <code>check\_timing</code> command checks for constraint problems such as undefined clocking, undefined input arrival times, and undefined output constraints. These constraint problems could cause you to overlook timing violations. For this reason, <code>check\_timing</code> is recommended whenever you apply new constraints such as clock definitions, I/O delays, or timing exceptions.

After the design is fully constrained, the report\_constraint command tells you whether the design meets the timing, area, power, and design rule constraints. It reports the existence of any violations and shows the amount by which each constraint is violated, information about the design object that is the worst violator, and the weighted cost of the violation. The verbose mode of the command gives you detailed information about the violations.

The report\_timing command provides detailed, point-by-point information on the clock paths and data paths that have the worst slack, along with the delay and slack calculation. You can control the scope of the design that is reported, the number of paths to report, and the types of path information that are included in the report. This information is very helpful in determining the cause of timing violations and how to fix them. The <code>get\_timing\_paths</code> command lets you create collections of timing paths for further analysis and processing.

The report\_clock\_timing command reports the clock latency, transition time, and skew characteristics at specified clock pins of sequential elements in the network. You specify the type of report you want, the scope of the design to analyze, and any desired filtering or ordering options for the report. The tool gathers the requested clock information and reports it in the specified order. The report is useful for debugging latency and skew problems in the clock network.

Table 7-1 lists the commands commonly used to check timing constraints, display timing analysis results, and report timing-related functions in Design Compiler and IC Compiler.

Table 7-1 Timing Reporting Commands

| Command                   | Description                                                                                                            |
|---------------------------|------------------------------------------------------------------------------------------------------------------------|
| all_connected             | Creates a collection of objects connected to a net, port, or pin                                                       |
| all_critical_cells        | Creates a collection of critical cells                                                                                 |
| all_critical_pins         | Creates a collection of critical pins                                                                                  |
| all_fanin                 | Creates a collection of pins or cells in transitive fanin                                                              |
| all_fanout                | Creates a collection of pins or cells in transitive fanout                                                             |
| all_inputs                | Creates a collection of input ports                                                                                    |
| all_outputs               | Creates a collection of output ports                                                                                   |
| all_registers             | Creates a collection of register cells or pins                                                                         |
| check_design              | Checks the design for consistency                                                                                      |
| check_timing              | Checks for timing constraint problems; see "check_timing Command" on page 7-5                                          |
| get_timing_paths          | Creates a collection of timing paths; see "get_timing_paths Command" on page 7-19                                      |
| report_annotated_delay    | Reports annotated delays; see "Reporting Annotated Delay Values" on page 6-17                                          |
| report_attribute          | Reports attributes of objects                                                                                          |
| report_case_analysis      | Reports case analysis settings; see "Reporting Case Analysis" on page 5-20                                             |
| report_cell               | Reports cells in the design                                                                                            |
| report_clock              | Reports clocks defined in the design; see "Reporting Clock Information" on page 2-12                                   |
| report_clock_gating       | Reports clock-gating cells and registers created by Power Compiler                                                     |
| report_clock_gating_check | Reports clock-gating timing checks                                                                                     |
| report_clock_timing       | Reports timing attributes of clock networks: latency, skew, transition; see "report_clock_timing Command" on page 7-22 |

Table 7-1 Timing Reporting Commands (Continued)

| Command                     | Description                                                                                                                         |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| report_clock_tree           | Reports structural and timing characteristics of compiled clock trees                                                               |
| report_constraint           | Reports constraints and constraint violations: timing, design rules, power; see "report_constraint Command" on page 7-7             |
| report_delay_calculation    | Reports calculation of a cell or net timing delay; see "Library Timing Data" on page 1-24                                           |
| report_design               | Reports design attributes: libraries, register type, operating conditions, wire load models, input/output delays                    |
| report_design_lib           | Reports contents of design libraries                                                                                                |
| report_disable_timing       | Reports timing arcs that have been disabled by case analysis, conditional arcs, loop breaking, or by the set_disable_timing command |
| report_hierarchy            | Reports the design hierarchy                                                                                                        |
| report_lib                  | Reports library information, including timing-related information; see "Library Timing Data" on page 1-24                           |
| report_net                  | Reports nets of the design                                                                                                          |
| report_port                 | Reports ports of the design                                                                                                         |
| report_qor                  | Reports quality of results: slack, cell count, and area                                                                             |
| report_reference            | Reports hierarchical cell references                                                                                                |
| report_timing               | Reports design timing (paths, slack, violations); see "report_timing Command" on page 7-10                                          |
| report_timing_derate        | Reports timing derate settings; see "Setting Derating Factors" on page 4-12                                                         |
| report_timing_requirement s | Reports timing exceptions; see "Reporting Exceptions" on page 3-27                                                                  |
| report_transitive_fanin     | Reports pins in the transitive fanin to a specified sink object                                                                     |
| report_transitive_fanout    | Reports pins in the transitive fanout from a specified source object                                                                |

Several of the reporting commands have a <code>-significant\_digits</code> option, which you can use to specify the number of digits to the right of the decimal point displayed in the report. This setting affects only the display of values in the report, not the precision used internally for calculations. The <code>report\_default\_significant\_digits</code> variable specifies the default number of significant digits displayed by all of the reporting commands.

The remaining sections of this chapter describe some of the more commonly used timingrelated reporting commands. For more information, see the man page for the applicable command.

### check\_timing Command

Paths that are incorrectly constrained might not appear in the violation reports, possibly causing you to overlook paths with violations. For this reason, the <code>check\_timing</code> command is recommended to check any new constraints such as clock definitions, I/O delays, or timing exceptions.

The <code>check\_timing</code> command checks for constraint problems such as undefined clocking, undefined input arrival times, and undefined output constraints. In addition, it provides information about potential problems related to minimum clock separation for master-slave clocking, ignored timing exceptions, combinational feedback loops, and latch fanout. You can correct unconstrained paths by adding new constraints using commands such as <code>create clock</code>, <code>set input delay</code>, and <code>set output delay</code>.

#### The syntax is:

```
check_timing
  [-overlap_tolerance minimum_distance]
  [-override_defaults check_list]
  [-include check_list]
  [-exclude check_list]
  [-multiple_clock]
  [-retain]
```

Here is an example of a typical check\_timing report:

```
prompt> check_timing
```

```
Information: Checking generated_clocks...
Information: Checking loops...
Information: Checking no_input_delay...
Information: Checking unconstrained_endpoints...
Warning: The following end-points are not constrained for maximum delay.
```

End point
----sd\_CK
sd\_CKn

By default, the <code>check\_timing</code> command performs several types of constraint checking and issues a report like the one shown in the foregoing example. To add to or subtract from the default list of checks, use the <code>-include</code> or <code>-exclude</code> option of the <code>check\_timing</code> command or set the <code>timing\_check\_defaults</code> variable to specify the list of checks for subsequent <code>check\_timing</code> commands. For more information, see the <code>check\_timing</code> man page.

Table 7-2 lists and briefly describes the conditions that the <code>check\_timing</code> command can detect. The types of checking that are performed by default are marked with an asterisk in the first column.

Table 7-2 Issues Detected by the check\_timing Command

| Potential problem         | Report results                                                                                                                                                                                                                                                                                  |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clock_crossing            | Checks interactions between multiple clocks. If a path is launched by one clock and captured by another, the clocks are reported. For each pair of interacting clocks, the report shows an asterisk if all the paths are false paths or a number sign (#) if some of the paths are false paths. |
| clock_no_period           | Issues a warning if a clock does not have a period specified.                                                                                                                                                                                                                                   |
| data_check_multiple_clock | Issues a warning if multiple clocked signals reach a data check register reference pin.                                                                                                                                                                                                         |
| data_check_no_clock       | Issues a warning if no clocked signal reaches a data check register reference pin. In that case, no setup or hold checks are performed on the constrained pin.                                                                                                                                  |
| gated_clock               | Issues a warning about any gated clocks found.                                                                                                                                                                                                                                                  |
| generated_clock*          | Checks the generated clock network and reports any of the following conditions: a source pin is not the clock source, a generated clock definition point has no path to the source point, or multiple generated clocks form a loop.                                                             |
| generic                   | Issues a warning about any unmapped cells in the design, which have zero delay.                                                                                                                                                                                                                 |
| ideal_timing              | Issues a warning about any ideal transition or latency set on a non-ideal pin.                                                                                                                                                                                                                  |

Table 7-2 Issues Detected by the check\_timing Command (Continued)

| Potential problem        | Report results                                                                                                                                                           |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| loops*                   | Issues a warning about any combinational feedback loops found.                                                                                                           |
| multiple_clock           | Issues a warning if multiple clocks reach a register pin.                                                                                                                |
| net_no_driving_info      | Issues a warning if a net has coupled parasitics but does not have a driving pin or there is no timing arc on the driver pin.                                            |
| no_driving_cell*         | Issues a warning if a port is connected to a net that has parasitic data, and the port does not have a driving cell.                                                     |
| no_input_delay*          | Issues a warning if no clock-related delay is specified for an input port, and there is no default clock (the timing_input_port_default_clock variable is set to false). |
| partial_input_delay*     | Issues a warning about any port that has only the minimum delay or only the maximum delay specified by the <pre>set_input_delay</pre> command.                           |
| pulse_clock_cell_type*   | Issues a warning about any cell instance that has a mismatched pulse type defined in the library.                                                                        |
| retain                   | Issues a warning about any retain timing-check value that is larger than its corresponding delay value.                                                                  |
| unconstrained_endpoints* | Shows unconstrained register data pins or primary outputs that are not marked as false paths.                                                                            |

<sup>\*</sup> Asterisk indicates a type of check that is enabled by default

### report\_constraint Command

The report\_constraint command produces a summary of the constraint violations in the design, including the amount by which each constraint is violated, information about the design object that is the worst violator, and the weighted cost of the violation.

The default report displays brief information about the worst evaluation for each constraint in the current design and the overall cost. For example,

### prompt> report\_constraint

. . .

| Group (max_delay/setup)                                                  |                    |        |                                                                         |
|--------------------------------------------------------------------------|--------------------|--------|-------------------------------------------------------------------------|
| CLK<br>default                                                           | 0.00               | 1.00   | 0.00<br>0.00                                                            |
| max_delay/setup                                                          |                    |        | 0.00                                                                    |
| Group (critical_range)                                                   | Total Neg<br>Slack |        | Cost                                                                    |
| CLK<br>default                                                           | 0.00               |        | 0.00                                                                    |
| critical_range                                                           |                    |        | 0.00                                                                    |
| Group (min_delay/hold)                                                   | Cost               | Weight | Weighted<br>Cost                                                        |
| CLK<br>default                                                           |                    | 1.00   |                                                                         |
| min_delay/hold                                                           |                    |        | 0.00                                                                    |
| Constraint                                                               |                    |        | Cost                                                                    |
| max_transition max_fanout max_capacitance max_delay/setup critical_range |                    |        | 0.01 (VIOLATED)<br>0.00 (MET)<br>0.00 (MET)<br>0.00 (MET)<br>0.00 (MET) |

The command reports all types of design constraints, such as area and power constraints, in addition to timing constraints. These are the command options that are relevant to timing analysis:

```
report_constraint
  [-all_violators]
  [-verbose]
  [-max_capacitance] [-min_capacitance]
  [-max_delay] [-min_delay]
  [-max_transition]
```

You can optionally restrict the scope of the report by specifying the appropriate options in the command, such as -max delay to report only maximum delay constraint violations. Use the -verbose option to get detailed information about the object that caused the worst violation or came closest to causing a violation. For example,

```
icc_shell> report_constraint -max_capacitance -max_transition -verbose
 Net: n234
2.00
                  2.01
                  -0.01 (VIOLATED)
  List of pins on net "n234" with transition violations :
 _____
                Required Actual
Transition Transition Slack
   PIN: U52/Z 2.00 2.01 -0.01 (VIOLATED)
  Net: I_PCI_TOP/I_PCI_READ_FIFO/we_n
max_capacitance 0.17
- Capacitance 0.12
            0.06 (MET)
  Slack
```

Getting a verbose report on a timing constraint such as maximum delay produces a timing report similar to that generated by the report\_timing command. The report shows the timing for the path that caused the worst violation or the smallest slack for each path group.

Use the -all violators to get a summary listing of all violators, including the path endpoints that caused timing violations. For example,

prompt> report\_constraint -all\_violators

I BLENDER\_1/s4\_op1\_reg\_30\_/D

```
max_delay/setup ('SYS_CLK' group)
                   Required Actual
        Required Actual
Path Delay Path Delay Slack
Endpoint
______
I_BLENDER_1/mega_shift_reg_2__30_/D
                              8.63 r -0.13 (VIOLATED)
I_BLENDER_1/mega_shift_reg_1__30_/D
                      8.52 8.61 r -0.09 (VIOLATED)
8.53 8.61 r -0.08 (VIOLATED)
I_BLENDER_1/mega_shift_reg_0__30_/D
```

8.60 r -0.07 (VIOLATED)

|                          | 8.52                   | 8.59 r               | -0.07          | (VIOLATED) |
|--------------------------|------------------------|----------------------|----------------|------------|
| I_BLENDER_1/s4_op2_reg_3 | 1_/D<br>8.54           | 8.61 f               | -0.07          | (VIOLATED) |
| I_BLENDER_1/s4_op1_reg_3 | 1_/D<br>8.54           | 8.57 f               | 0 00           |            |
|                          | 8.54                   | 8.5/ 1               | -0.02          | (VIOLATED) |
| max_transition           |                        |                      |                |            |
| Net                      | Required<br>Transition | Actual<br>Transition | Slack          |            |
| n234 PIN: U52/Z          | 2.00                   | 2.01<br>2.01         | -0.01<br>-0.01 | (VIOLATED) |

# report\_timing Command

The report\_timing command provides detailed, point-by-point timing information for the paths that have the worst slack. You can control the scope of the design that is reported, the number of paths to report, and the types of path information to include in the report. The information in the report can help you determine how to fix the violations.

### report\_timing Report Contents

The following is a typical path timing report generated by the report\_timing command.

| Point                                                            | Incr   | Path   |
|------------------------------------------------------------------|--------|--------|
| clock SYS 2x CLK (rise edge)                                     | 0.00   | 0.00   |
| clock network delay (propagated)                                 | 0.51   | 0.51   |
| <pre>I_RISC_CORE/I_INSTRN_LAT/Instrn_1_reg_27_/CP (senrq1)</pre> | 0.00   | 0.51 r |
| <pre>I_RISC_CORE/I_INSTRN_LAT/Instrn_1_reg_27_/Q (senrq1)</pre>  | 0.62   | 1.13 f |
| I_RISC_CORE/I_INSTRN_LAT/Instrn_1[27] (INSTRN_LAT)               | 0.00   | 1.13 f |
| I_RISC_CORE/I_ALU/ALU_OP[3] (ALU)                                | 0.00   | 1.13 f |
| I_RISC_CORE/I_ALU/U288/ZN (nr03d0)                               | 0.36 * | 1.49 r |
| I_RISC_CORE/I_ALU/U261/ZN (nd03d0)                               | 0.94 * | 2.43 f |
| I_RISC_CORE/I_ALU/U307/ZN (invbd2)                               | 0.35 * | 2.78 r |
| I_RISC_CORE/I_ALU/U343/Z (an02d1)                                | 0.16 * | 2.93 r |
| I_RISC_CORE/I_ALU/U344/ZN (nr02d0)                               | 0.11 * | 3.04 f |

| <pre>I_RISC_CORE/I_ALU/U348/ZN (nd03d0) I_RISC_CORE/I_ALU/U355/ZN (nr03d0) I_RISC_CORE/I_ALU/U38/Z (an02d1) I_RISC_CORE/I_ALU/U40/Z (an02d1) I_RISC_CORE/I_ALU/U48/ZN (nd02d1) I_RISC_CORE/I_ALU/U27/ZN (nd02d1) I_RISC_CORE/I_ALU/Zro_Flag_reg/D (secrq4) data arrival time</pre> | 0.28 * 0.29 * 0.15 * 0.12 * 0.06 * 0.06 * 0.00 * | 3.93 r<br>3.99 f                               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|------------------------------------------------|
| <pre>clock SYS_2x_CLK (rise edge) clock network delay (propagated) clock uncertainty I_RISC_CORE/I_ALU/Zro_Flag_reg/CP (secrq4) library setup time data required time</pre>                                                                                                        | 4.00<br>0.47<br>-0.10<br>0.00<br>-0.37           | 4.00<br>4.47<br>4.37<br>4.37 r<br>4.00<br>4.00 |
| data required time data arrival time                                                                                                                                                                                                                                               |                                                  | 4.00<br>-3.99                                  |
| slack (MET)                                                                                                                                                                                                                                                                        |                                                  | 0.01                                           |

In this example, the logic associated with the reported path is shown in Figure 7-1.

Figure 7-1 Timing Path Logic



The report starts by showing the path startpoint, path endpoint, path group name, and path timing check type. In this example, the path timing check type is shown as "max," which means a maximum-delay or setup check; "min" would mean a minimum-delay or hold check.

The table shows point-by-point accounting of the delays along the path from the startpoint to the endpoint. The table has columns labeled Point, Incr, and Path. These columns list the points (cell pins) along the path, the incremental contribution to the delay at each point, and the cumulative delay up to that point, respectively. The table also lists the hierarchical boundary crossings, showing zero incremental delay at each crossing.

The asterisk (\*) symbols in the Incr column show where SDF back-annotated delay values were used for the net delay. The letters "r" and "f" in the Path column indicate the sense of the signal transition, either rising or falling, at that point in the path.

The path starts with the launch clock edge and ends at the data input of the capture device. The "data arrival time" shown in the table is the amount of elapsed time from the source of the launch clock edge to the arrival of data at the endpoint, taking into consideration the longest possible delays along the path.

After this is the accounting for the required arrival time. The "data required time" shown in the table is the latest allowable arrival time for the data at the path endpoint, taking into account the nominal capture clock edge time, the clock network delay, the clock uncertainty, the least possible delay along the clock path, and the library setup time requirement for the capture device.

The required time is subject to adjustment for clock reconvergence pessimism removal (CRPR). When this feature is enabled, the tool checks for the presence of a shared segment between the launch clock path and capture clock path, such as buffer U2 in the foregoing circuit diagram. The calculated slack is pessimistic if different delay values are used in the common segment for launch and for capture. This pessimism is removed by the CRPR function. For details, see "Clock Reconvergence Pessimism Removal" on page 4-16.

The slack value shown at the end of the report is simply the data required time minus the data arrival time. The slack is the amount of time by which the timing constraint is met, considering the latest possible arrival of data at the endpoint and the earliest possible arrival of the capture clock edge.

You can control the level of detail provided in the report by using the report\_timing command options. For example, to show incremental cell and net delays separately rather than combined, use the -input\_pins option. To show the point-by-point delays in the clock clock paths as well as in the data path, use the -path\_full\_clock\_expanded option.

### report\_timing Command Options

The report\_timing command offers a large number of options to control the scope of the design that is reported, the number of paths to report, and the types of path information to include in the report. This is the full syntax of the command:

```
report_timing
 [-to to_list] [-rise_to to_list] [-fall_to to_list]
 [-from from_list] [-rise_from from_list] [-fall_from from_list]
 [-through through_list]
   [-rise_through through_list]
   [-fall_through through_list]
 [-path short | full | full_clock | full_clock_expanded | only | end]
 [-delay min | min_rise | min_fall | max | max_rise | max_fall]
 [-nworst paths_per_endpoint]
 [-max_paths max_path_count]
 [-input_pins]
 [-nets]
 [-transition_time]
 [-crosstalk delta]
 [-capacitance]
 [-attributes]
 [-physical]
 [-slack_greater_than greater_slack_limit]
 [-slack lesser than lesser slack limit]
 [-lesser path max path delay]
 [-greater_path min_path_delay]
 [-loops]
 [-true [-true threshold path delay]]
 [-justify]
 [-enable_preset_clear_arcs]
 [-significant digits digits]
 [-nosplit]
 [-sort_by group | slack]
 [-group group_name]
 [-trace_latch_borrow]
 [-derate]
 [-scenario scenario list]
 [-temperature]
 [-voltage]
```

By default, the report\_timing command by itself, without any options, reports the single worst maximum-delay (setup) path in each path group. Therefore, the number of paths reported is equal to the number of path groups. By default, there is one path group per clock used in the design.

### Scope of the Design Reported

The <code>-from</code>, <code>-through</code>, and <code>-to</code> options restrict the scope of the report to only those paths that start, pass through, and end at the specified objects in the design. The options <code>-rise\_from</code>, <code>-fall\_to</code>, and so on, further restrict the scope to only those paths that have a rising-edge signal at the startpoint, a falling-edge signal at the endpoint, and so on. The specified object can be a clock, a port, or a pin of a launch or capture cell.

For example, the following command restricts the scope of the report to only those paths that start and end at specified objects:

```
prompt> report_timing -from [get_pins reg08/CP] -to [get_clocks CLK1]
```

This command reports the single path having the worst maximum-delay (setup) slack that starts with a rising-edge signal at the CP pin of cell reg08 and ends at a register or port clocked by CLK1.

You can use (or not use) any combination of -from, -through, and -to type options. For details, see "Path Specification Methods" on page 3-4.

To restrict the scope of the report to a particular path group, use the <code>-group</code> option. For example, to report only the paths in the CLK1 path group,

```
prompt> report_timing -group CLK1
```

By default, paths are divided into groups according to the endpoint clock. For example, a design that has clocks named CLK1 and CLK2 has two path groups named CLK1 and CLK2. You can also specify your own path grouping with the group\_path command. For details, see "Path Groups" on page 3-2.

### **Path Details Reported**

By default, each line of the path report shows the point along the path, the incremental contribution to the delay of the point, and the cumulative delay up to that point. Each point includes both the cell and net delay from the previous point. For example,

```
prompt> report_timing
```

| Point                                                                               |          | Incr                 | Path                       |
|-------------------------------------------------------------------------------------|----------|----------------------|----------------------------|
| I_BLENDER_1/mult_50/U701/CO I_BLENDER_1/mult_50/U698/CO I_BLENDER_1/mult_50/U699/CO | (ad01d0) | 0.24<br>0.26<br>0.29 | 4.93 f<br>5.19 f<br>5.48 f |

To display the net names associated with the timing points, use the -nets option:

```
prompt> report_timing -nets
```

Point Fanout Incr Path
....

I\_BLENDER\_1/mult\_50/U701/CO (ad01d2) 0.24 4.93 f

I\_BLENDER\_1/mult\_50/n842 (net)

1 0.00 4.93 f

I\_BLENDER\_1/mult\_50/U698/CO (ad01d0) 0.26 5.19 f

I\_BLENDER\_1/mult\_50/n843 (net)

1 0.00 5.19 f

I\_BLENDER\_1/mult\_50/U699/CO (ad01d0) 0.29 5.48 f

I\_BLENDER\_1/mult\_50/n844 (net)

To display net delays separately from the cell delays, use the <code>-input\_pins</code> option, which lists the cell input pins as well as the cell output pins as timing points:

0.00 5.48 f

```
prompt> report_timing -input_pins -significant_digits 5
```

. . .

. . .

| Point                                                                                                                                                                   |                                              | Incr                                                           | Path                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------|
| I_BLENDER_1/mult_50/U701/CI I_BLENDER_1/mult_50/U701/CO I_BLENDER_1/mult_50/U698/CI I_BLENDER_1/mult_50/U698/CO I_BLENDER_1/mult_50/U699/CI I_BLENDER_1/mult_50/U699/CO | (ad01d2)<br>(ad01d0)<br>(ad01d0)<br>(ad01d0) | 0.00005<br>0.24126<br>0.00005<br>0.25960<br>0.00005<br>0.29044 | 4.69329 f<br>4.93454 f<br>4.93459 f<br>5.19420 f<br>5.19424 f<br>5.48468 f |

The incremental delay leading up to a cell input is a net delay. The incremental delay leading up to a cell output is the cell delay.

To display the signal transition time at each timing point, use the -transition time option:

prompt> report\_timing -transition\_time

. . .

|   | Point                           | Trans    | Incr | Path   |
|---|---------------------------------|----------|------|--------|
| _ | <br>I_BLENDER_1/mult_50/U701/CO | (ad01d2) |      |        |
|   | I BLENDER 1/mult 50/U698/CO     | 0.13     | 0.24 | 4.93 f |
|   | 1_DDD1(_1/1(d16_30/0030/60      | 0.21     | 0.26 | 5.19 f |

Similarly, use the <code>-capacitance</code> option to display the net capacitance, <code>-physical</code> to display the physical locations of the driver and load pins, and so on. You can combine multiple options of this type in a single command. The tool increases the number of columns in the report as needed.

The -path option specifies what type of timing points are included in the path report. It can be set to short, full, full\_clock, full\_clock\_expanded, only, or end. The default report type is full.

A full\_clock report is like a full report, except that it also reports the timing points in the clock paths leading up to the launch and capture devices. A full\_clock\_expanded report is like a full\_clock report, except that it also reports the timing points between a primary source clock and a generated clock. For example,

### prompt> report\_timing -path full\_clock

Startpoint: I BLENDER 1/mega shift reg 3 24

```
(rising edge-triggered flip-flop clocked by SYS_CLK)
...

Point Incr Path

clock SYS_CLK (rise edge) 0.00 0.00

sys_clk (in) 0.07 0.07 r

I_BLENDER_1/U483/Z (ora21d4) 0.34 0.41 r

I_BLENDER_1/buffd4_G2B1I2/Z (buffd4) 0.20 0.60 r

I_BLENDER_1/bufbd7_G2B2I2/Z (bufbd7) 0.22 0.83 r

I_BLENDER_1/mega_shift_reg_3_24_/CP (sdcrq1) 0.00 0.83 r

I_BLENDER_1/mega_shift_reg_3_24_/Q (sdcrq1) 0.40 1.23 r
```

A short report shows only the startpoint and endpoint, omitting the intermediate points. An only report shows the data path only and omits the required-time and slack calculation.

An end report shows only the endpoint, delay, required time, and slack in a single line, but all endpoints are reported instead of just the single worst path per path group. The -path end option is typically used with the -nworst option to restrict the report length. For example,

prompt> report\_timing -path end -max\_paths 5

| Endpoint                                 | Path Delay      | Path Required | Slack |
|------------------------------------------|-----------------|---------------|-------|
| I_BLENDER_1/mega_shift_reg_2_            | _30_/D (sdcrq1) |               |       |
|                                          | 8.64 r          | 8.51          | -0.13 |
| I_BLENDER_1/s4_op2_reg_30_/D             | (sdnrq1)        |               |       |
|                                          | 8.63 r          | 8.54          | -0.09 |
| <pre>I_BLENDER_1/mega_shift_reg_0_</pre> | _30_/D (sdcrq1) |               |       |
|                                          | 8.61 r          | 8.52          | -0.09 |
| <pre>I_BLENDER_1/mega_shift_reg_1_</pre> | _30_/D (sdcrq1) |               |       |
|                                          | 8.62 r          | 8.53          | -0.09 |
| I_BLENDER_1/s4_op1_reg_30_/D             | (sdnrq1)        |               |       |
|                                          | 8.61 r          | 8.53          | -0.08 |

### Delay Type (Min/Max) Reported

By default, the report\_timing command reports the path or paths having the worst maximum-delay (setup) slack resulting from the longest delays and earliest required times. To get a report on the paths having the worst minimum-delay (hold) slack instead, use the -delay min option. In that case, the command looks for the shortest delays and latest required times. The minimum-delay slack is the arrival time minus the required time.

You can similarly use <code>-delay min\_rise</code>, <code>-delay max\_fall</code>, and so on to restrict the scope of the report to just rising or just falling edges of the data signal at the path endpoint.

# **Number of Paths Reported**

The options -nworst and -max\_paths options control the number of paths reported. The -nworst option specifies the number of paths reported per endpoint. The -max\_paths option specifies the number of paths reported per path group.

For example, the following command reports the eight worst maximum-delay paths per path group, but no more than two paths per endpoint:

```
prompt> report timing -nworst 2 -max paths 8
```

If the three worst maximum-delay paths in a path group have the same endpoint, only the first two are reported; the third-worst path reported must have a different endpoint in the path group.

The options <code>-slack\_lesser\_than</code> and <code>-slack\_greater\_than</code> restrict the report to paths that have slack values within the specified range. For example, the following command lists up to 50 worst maximum-delay paths per path group that have a slack less than 0.5:

```
prompt> report_timing -path end -max_paths 50 -slack_lesser_than 0.5
```

The command reports the paths in order of slack, starting with the worst path, and continues until 50 paths have been reported or until the slack exceeds 0.5 time units.

### **Other Options**

The report\_timing command has several more options not described here. For information about them see the man page for the report timing command.

#### Note:

The -justify, -true, and -true\_threshold options to the report\_timing command require a DC Ultra license.

# report\_delay\_calculation Command

For a detailed description of the delay calculation for a particular cell instance or net in the design, you can use the report\_delay\_calculation command. For example,

```
icc_shell> report_delay_calculation -from I_RISC_CORE/I_ALU/U27/A2 \
          -to I_RISC_CORE/I_ALU/U27/ZN
Rise Delay
  cell delay = 0.0583731
    Table is indexed by
     (X) input_pin_transition = 0.103374
     (Y) output_net_total_cap = 0.00451049
    Relevant portion of lookup table:
                 (X) 0.0150
                                  (X) 0.2500
                  (Z) 0.0270
                                  (Z) 0.0680
  (Y) 0.0000
  (Y) 0.0070
                 (Z) 0.0480
                                  (Z) 0.0990
    Z = A + B*X + C*Y + D*X*Y
    A = 0.0244 B = 0.1745
    C = 2.9088
                        D = 6.0790
 Z = 0.0583731
 scaling result for operating conditions
 multiplying by 1 gives 0.0583731
```

In the report\_delay\_calculation command, you must specify a "from" pin and a "to" pin. The two specified pins must be either an input pin and an output pin of a cell instance or the driver pin and a load pin of a net. The command gives a detailed report on the calculation of the delay from the "from" pin to the "to" pin, including library data used, operating conditions, and transition times.

### get\_timing\_paths Command

You can use the <code>get\_timing\_paths</code> command to create a collection of paths for custom reporting and other processing. You can assign these timing paths to a variable or pass them into another command. From the collection variable, you can query the collection to obtain the path attributes such as the slack, timing points, and intermediate delays.

Use the foreach\_in\_collection command to iterate among the paths in the collection. The index\_collection, copy\_collection, add\_to\_collection, and remove\_from\_collection commands are not applicable to timing path collections. You can use the get\_attribute command to obtain information about the paths.

The following example shows how to create a path collection, set a variable to that collection, and extract information about the path from the variable.

```
prompt> set mypath [get_timing_paths -delay_type max -group SYS_CLK]
{path1}
prompt> get_attribute $mypath endpoint
{"I_BLENDER_1/mega_shift_reg_2__30_/D"}
prompt> get_attribute $mypath endpoint_clock_pin
{"I_BLENDER_1/mega_shift_reg_2__30_/CP"}
prompt> get_attribute $mypath arrival
8.45935
prompt> get_attribute $mypath slack
0.0432777
```

The following example shows how to iterate through a path collection to extract attributes from each path in the collection.

```
{I_BLENDER_1/mega_shift_reg_3__24_/CP} 0.0475168  
{I_BLENDER_1/mega_shift_reg_1__30_/D} 
{I_BLENDER_1/mega_shift_reg_2__0_/CP} 0.0796604
```

The first command creates a collection containing the ten worst maximum-delay (setup) timing paths clocked by SYS\_CLK, with no more than two paths per endpoint. The next command iterates through the collection using "iter" as the iteration variable, and extracts the endpoint, startpoint, and slack of each path.

#### Note:

When iterating over a collection, to avoid excessive runtime, avoid writing scripts that use a large number of current\_design commands in a loop.

Table 7-3 shows the attributes supported on timing paths.

Table 7-3 Attributes Supported on Timing Paths

| Attribute                       | Туре    |
|---------------------------------|---------|
| clock_uncertainty               | float   |
| endpoint                        | string  |
| endpoint_clock                  | string  |
| endpoint_clock_close_edge_type  | string  |
| endpoint_clock_close_edge_value | float   |
| endpoint_clock_is_inverted      | Boolean |
| endpoint_clock_is_propagated    | Boolean |
| endpoint_clock_open_edge_type   | string  |
| endpoint_clock_open_edge_value  | float   |
| endpoint_clock_pin              | string  |
| endpoint_hold_time_value        | float   |
| endpoint_is_level_sensitive     | Boolean |
| endpoint_output_delay_value     | float   |

Table 7-3 Attributes Supported on Timing Paths (Continued)

| Attribute                        | Туре    |
|----------------------------------|---------|
| endpoint_recovery_time_value     | float   |
| endpoint_removal_time_value      | float   |
| endpoint_setup_time_value        | float   |
| object_class                     | string  |
| path_group                       | string  |
| path_type                        | string  |
| points                           | string  |
| slack                            | string  |
| startpoint                       | string  |
| startpoint_clock                 | string  |
| startpoint_clock_is_inverted     | Boolean |
| startpoint_clock_is_propagated   | Boolean |
| startpoint_clock_latency         | float   |
| startpoint_clock_open_edge_type  | float   |
| startpoint_clock_open_edge_value | float   |
| startpoint_input_delays_value    | float   |
| startpoint_is_level_sensitive    | Boolean |
| time_borrowed_from_endpoint      | float   |
| time_lent_to_startpoint          | float   |

One attribute of a timing path is the points collection. A point corresponds to a pin or port along the path. Iterate through these points using the foreach\_in\_collection command and get the attributes on them using the get\_attribute command. Table 7-4 shows the attributes supported for a point of a timing path.

Table 7-4 Attributes Supported for Points of a Timing Path

| Attribute    | Туре   |
|--------------|--------|
| arrival      | string |
| object       | string |
| object_class | string |
| rise_fall    | string |
| slack        | string |

To create a collection of clock groups in the design, use the get\_path\_groups command.

For more information, see the man pages for the collection commands (man collections), the get timing paths command, and the foreach in collection command.

# report\_clock\_timing Command

The report\_clock\_timing command reports the clock latency, transition time, and skew characteristics at specified clock pins of sequential elements in the network. In the command, you specify the type of report you want (latency, transition time, single-clock skew, interclock skew, or summary), the scope of the design to analyze, and any desired filtering or ordering options for the report. The tool gathers the requested information and reports it in the specified order.

# **Latency and Transition Time Reporting**

The information reported by the report\_clock\_timing command is based on the clock latency and transition times calculated by the tool. This information is maintained for all clock pins of sequential devices in the design.

The clock latency at a particular pin depends on the following analysis conditions:

- Constraint type: setup or hold
- Timing path role: launch or capture
- Transition type: rise or fall

To restrict the scope of the report\_clock\_timing command, you can optionally specify the pins to analyze and the conditions at those pins. For example,

In this example, the tool reports the latency at pin U1/CP for a hold check, for data capture at the flip-flop, for a rising edge at the clock pin. If you specify neither <code>-rise</code> nor <code>-fall</code>, the tool considers the device type, in conjunction with its launch or capture role, to determine the appropriate transition to report.

Using the -to option, you can selectively restrict the scope of the design checked for the report. For example,

When a pin named in the "to" list is not a clock pin of a sequential element, the tool replaces that pin with the set of clock pins in the transitive fanout of the named pin. Here, "clock pin" means the clock pin of a flip-flop or the gate pin of a latch.

# **Skew Reporting**

To get a single-clock skew report, use the <code>report\_clock\_timing -type</code> skew command. This generates a report on skews between pins clocked by the same clock. To get a report on skews between pins clocked by different clocks as well as by the same clock, use the <code>report\_clock\_timing -type interclock\_skew</code> command, as described in the section "Interclock Skew Reporting" on page 7-25.

The skew between the clock pins of two different sequential devices is the difference between the latency values of the two pins, as illustrated in Figure 7-2. The tool calculates the latency at points A and B, and then subtracts latency at A from the latency at B to obtain the clock skew.

Figure 7-2 Clock Skew Calculation



Skew = (latency at B) - (latency at A) [ - (clock reconvergence pessimism) ]

To determine the latency at the two pins for skew calculation, the tool considers the following conditions at each pin:

- Type of sequential device involved: rising or falling edge-sensitive; or high or low levelsensitive
- Type of constraint: setup or hold, which determines the path type, transition type, and library data used
- Role of the sequential device in the constraint relationship: launch or capture

If clock reconvergence pessimism removal is enabled, the tool takes it into account for the skew calculation. For details, see "Clock Reconvergence Pessimism Removal" on page 4-16.

You can optionally restrict the scope of the report by specifying "from" and "to" pins in the design. For example, to get a report on the clock skew for a setup path between a negative-level-sensitive launch latch and a positive-edge-triggered capture flip-flop, you would use a command like this:

The tool reports the skew between a pair of sequential devices only if they can communicate by one or more data paths in the specified "from" and "to" direction. The existence of such a data path is sufficient for reporting. The tool does not check to see whether the path has been declared false.

To find the worst skew between any pair of sequential devices, you can specify <code>-from</code> without <code>-to</code> or <code>-to</code> without <code>-from</code>. For the unspecified pins, the tool uses the set of all sequential device clock pins in the design that communicate with the pins in the specified direction. To restrict the clocks considered in the report, use the <code>-clock clock\_list</code> option. To include clock uncertainty in the skew calculation, use the <code>-include uncertainty in skew option</code>.

Like the report\_timing command, the report\_clock\_timing command calculates skew based on the opening edge at the "to" device, even for a level-sensitive latch that allows time borrowing.

## **Interclock Skew Reporting**

To get a report on skew between pins clocked by different clocks as well as by the same clock, use the report\_clock\_timing -type interclock\_skew command. An interclock skew report can help you get the following information:

- The skew between pin A, clocked by CLK1, and pin B, clocked by CLK2
- The worst local skew between all sequential devices clocked by CLK1 and all sequential devices clocked by CLK2
- The ten worst skews to all devices that communicate with pin A, irrespective of their domain.

You can restrict the scope of the report by using the  $-from\_clock$   $from\_clock\_list$  option or the  $-to\_clock$   $to\_clock\_list$  option, or both options. Because of the potentially large number of clock pins that the tool must analyze, be as specific as possible when you specify an interclock skew report.

To display the names of the "from" clock and the "to" clock in the interclock skew report, use the -show clocks option in the report clock timing command.

## **Clock Timing Reporting Options**

The report\_clock\_timing command offers several different types of reports, as summarized in Figure 7-3. The figure shows the report types, starting with the most general type at the top (summary report) and ending with the most specific type at the bottom (verbose report). The figure also shows an example of each type of command.

Figure 7-3 Clock Network Timing Report Types

#### Clock network report



## **Summary Report**

12\_3/G

f2 1/CP

f2\_2/CP

Maximum setup skew: f2 2/CP

Maximum hold skew: f3\_3/CP

A summary report shows a list of the minimum and maximum latency, transition time, and clock skew values found in the requested scope of the clock network. For example,

prompt> report\_clock\_timing -type summary -clock [get\_clocks CLK1] Clock: CLK1 Maximum setup launch latency: f2\_2/CP 6.11 rp-+ Minimum setup capture latency: f1 2/CP 1.00 rpi-+ Minimum hold launch latency: f1\_2/CP 1.00 rpi-+ Maximum hold capture latency: f2 2/CP 6.11 rp-+ Maximum active transition: 13\_2/G 0.13 rpi-Minimum active transition:

0.00

4.00

3.01

rp-

rp-+

rp-+

rpi-+

rp-+

The report shows the following information for each minimum and maximum latency, transition time, and skew value:

- Pins at which the minimum or maximum value occurred
- Minimum or maximum time value
- Conditions under which the minimum or maximum time value occurred

The string of characters in the rightmost column shows the conditions under which the minimum or maximum time value occurred, following the conventions shown in Figure 7-4.

Figure 7-4 Latency, Transition Time, and Skew Condition Codes



To restrict the scope of the report, you can use the -from and -to options of the command. For example,

This command restricts the scope of the report to CLK1 latency and transition times at pins A through E, and restricts the scope of the skew report to CLK1 skew between the pin groups {A B C} and {D E}.

#### **List Report**

A list report provides latency, transition time, and skew information in greater detail than a summary report. You can have the tool gather, filter, and display a collection of clock pins according to a specified attribute of interest.

There are two types of lists: skew reports and pin reports. A skew report lists pin pairs and shows the skew value for each pair. A pin report lists individual pins and shows the transition time and latency values for each pin. The items are listed in order of skew, transition time, or latency, as specified by the options in the report\_clock\_timing command.

An example of a command to generate a skew report is as follows:

```
prompt> report_clock_timing -clock CLK1 -type skew -setup -nworst 3
```

The report shows the three largest skew values listed in order of decreasing skew, together with the latency at each pin and the clock reconvergence pessimism used in the skew calculation:

| $\alpha$ 1 | oale. | CL <sub>K</sub> 1 |
|------------|-------|-------------------|
| (:1        | ock:  | CLKI              |

| Clock Pin          | Latency      | CRP   | Skew |              |
|--------------------|--------------|-------|------|--------------|
| f2_2/CP<br>f2_1/CP | 6.11<br>2.01 | -0.10 | 4.00 | rp-+<br>rp-+ |
| 12_2/G<br>f1_2/CP  | 4.11         | -0.10 | 3.01 | rp-<br>rpi-+ |
| f2_2/CP<br>13_3/G  | 6.11<br>3.01 | -0.10 | 3.00 | rp-+<br>rp-  |

The rightmost column shows the conditions under which the reported values occurred at each corresponding pin, using the codes shown in Figure 7-4.

Here is an example of a command used to generate an interclock skew report:

| Clock Pin          | Latency      | Uncert | Skew |              |
|--------------------|--------------|--------|------|--------------|
| f2_2/CP<br>f2_1/CP | 6.11<br>2.01 | 0.11   | 4.21 | rp-+<br>fp-+ |

The report shows the 12 largest skew values between clock pins anywhere in the design, whether clocked by the same clock or by different clocks. The report starts by showing the number of startpoint and endpoint pins and clocks under consideration. Very large numbers of startpoints and endpoints can serve as a warning about a potentially long runtime to generate the rest of the report.

To show the names of the two clocks for each entry in the interclock skew report, use the <code>-show\_clocks</code> option of the command.

Here is an example of a command to generate a pin report:

```
prompt> report_clock_timing -clock CLK1 -type transition -nworst 5
```

The report shows the five largest transition times listed in decreasing order, together with the source, network, and total latency of the corresponding pins:

| Clock: CLK1                                      |                                      |                                      |                                      |                                      |                                      |
|--------------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| Clock Pin                                        | Source                               | Latency -<br>Network                 | <br>Total                            | Trans                                |                                      |
| 13_2/G<br>f3_1/CP<br>12_1/G<br>f3_3/CP<br>13_3/G | 0.10<br>0.11<br>0.10<br>0.10<br>0.11 | 4.00<br>3.00<br>4.00<br>3.00<br>3.00 | 4.10<br>3.11<br>4.10<br>3.10<br>3.11 | 0.13<br>0.12<br>0.10<br>0.08<br>0.06 | rpi-<br>rp-+<br>rpi-<br>rpi-+<br>rp- |

The rightmost column shows the conditions under which the reported values occurred, using the codes shown in Figure 7-4.

To get a list of the largest latency values rather than transition times, use -type latency instead of -type transition.

## **Verbose (Path) Report**

The most detailed type of clock network timing report is the verbose, path-based report. This type of report shows the calculation of skew, latency, and transition times along the clock path. For example,

This command produces a report showing the transition time, incremental delay, and total latency along the clock paths to the specified pins; and the clock skew between the two pins:

Clock: CLK1

Startpoint: f3\_3 (rising edge-triggered flip-flop clocked
 by CLK1')
Endpoint: f2\_2 (rising edge-triggered flip-flop clocked
 by CLK1)

| Point                                                                                                                                                         | Trans                                                | Incr                                               | Path                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------|--------------------------------------|
| clock source latency clk3 (in) bf3_3_1/Z (B1I) bf3_3_2/Z (B1I) if3_3_1/Z (IVA) f3_3/CP (FD1) startpoint clock latency                                         | 0.00<br>0.01<br>0.00<br>0.04<br>0.04                 | 0.00<br>0.00<br>1.00 H<br>1.00 H<br>1.00 H<br>0.00 | 0.00 f<br>1.00 f<br>2.00 f<br>3.00 r |
| clock source latency clk2 (in) az_1/Z (B1I) az_2/Z (B1I) bf2_2_1/Z (B1I) if2_2_1/Z (IVA) bf2_2_2/Z (B1I) if2_2_2/Z (IVA) f2_2/CP (FD1) endpoint clock latency | 0.00<br>0.09<br>0.13<br>0.02<br>0.44<br>0.01<br>0.13 |                                                    | 3.11 r<br>4.11 f<br>5.11 f<br>6.11 r |
| endpoint clock latency<br>startpoint clock latency<br>clock reconvergence pess<br>inter-clock uncertainty                                                     |                                                      |                                                    | 6.11<br>-3.00<br>-0.10<br>0.21       |
| skew                                                                                                                                                          |                                                      |                                                    | 3.22                                 |

A command using the -latency or -transition option rather than the -skew option produces a similar report, except that only one clock path is reported rather than two.

To include information in the path report about the net delays, net names, net capacitance, cell and net attributes, or physical locations of pins in the path, use the <code>-input\_pins</code>, <code>-nets</code>, <code>-capacitance</code>, <code>-attributes</code>, or <code>-physical</code> option. These options are similar to those available in the <code>report\_timing</code> command.

If the "from" and "to" lists in the command contain a large number of pins, execution of the command can take a long time due to the large number of paths that must be checked.

# 8

## Graphical User Interface

The graphical user interface (GUI) provides a way to view design data and timing analysis results in graphical form, including schematics, layout views, histograms, data tables, and reports. Using the GUI for timing analysis is described in the following sections:

- Using the GUI for Timing Analysis
- Path Slack Histogram
- Path Inspector
- Timing Analysis Driver

## **Using the GUI for Timing Analysis**

The graphical user interface (GUI) of the Design Compiler and IC Compiler tools can help you visualize and understand the nature of timing problems in the design, including the type, number, magnitude, and locations of the paths, cells, and nets that are causing timing problems. Using the GUI, you can do the following:

- Browse the logical hierarchy graphically
- Generate path slack histograms
- Select and examine timing paths using text, schematics, spreadsheets, and delay profiles
- Display the physical locations of problem paths, cells, and nets in the IC Compiler layout window

To start the GUI from the tool's shell prompt, use the gui\_start command:

```
prompt> gui_start
```

In Design Compiler, starting the GUI opens the Design Vision top-level design window, from which you can view the design hierarchy and perform a wide range of synthesis functions, including timing analysis. Figure 8-1 shows the Design Vision window.



Figure 8-1 Design Vision (Design Compiler GUI) Window

In IC Compiler, starting the GUI opens the IC Compiler main window, from which you can perform a wide range of physical implementation functions. You can display the physical layout and perform timing analysis in separate windows called the layout window and timing window. To open the timing window from the main window, choose Window > New Timing Analysis Window, or from the layout window, choose Timing > New Timing Analysis Window. Figure 8-2 shows the IC Compiler timing analysis window.



Figure 8-2 IC Compiler Timing Analysis Window

In the Design Vision window or IC Compiler timing analysis window, you can use the buttons shown in Figure 8-3 to open a path slack histogram, endpoint slack histogram, net capacitance histogram, or path delay profile. Additional timing analysis commands are available in the tool's Timing menu.

Figure 8-3 Timing Analysis Buttons



Online help on using the GUI is available in the GUI itself. In the Design Compiler GUI, choose Help > Online Help, or in the IC Compiler GUI, choose Help > IC Compiler Online Help. For general information on using the GUI, see the *Design Vision User Guide* in the Design Compiler documentation set or the *IC Compiler Implementation User Guide* in the IC Compiler documentation set on SolvNet (https://solvnet.synopsys.com).

To stop the GUI while still keeping the original shell session, use the <code>gui\_stop</code> command or the File > Close GUI menu command.

## **Timing Menu Commands**

Table 8-1 lists and briefly describes the commands available in the Timing menu of the top-level Design Vision window and in the IC Compiler timing analysis window.

Table 8-1 Design Vision and IC Compiler Timing Menu Commands

| Menu command                                            | Action taken                                                                                                                                                                                                    |
|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timing > Path Inspector (Design Vision only)            | Displays the path inspector window, which shows a wide range of information about the selected path, including a complete path schematic, clocking information, and timing information.                         |
| Timing > Timing Analysis<br>Driver (Design Vision only) | Displays the timing analysis driver, which lists the timing paths having the worst slack in spreadsheet form. You can sort, filter, and modify the data in the table and examine any particular path in detail. |
| Timing > Path Slack                                     | Displays a histogram of slack values for a set of paths that you specify by startpoint, endpoint, number of paths, group name, and delay type.                                                                  |
| Timing > Slack Histogram of Selected Logic              | Displays a histogram of slack values for the paths whose endpoints are currently selected in a logic schematic.                                                                                                 |
| Timing > Slack Histogram of Selected Paths              | Displays a histogram of slack values for the currently selected paths.                                                                                                                                          |
| Timing > Endpoint Slack                                 | Displays a histogram of slack values for a specified range of slack, reporting no more than one path per endpoint.                                                                                              |
| Timing > Net Capacitance                                | Displays a histogram of net capacitance values for a specified range of capacitance values.                                                                                                                     |
| Timing > Capacitance of Selected Nets                   | Displays a histogram of net capacitance values for the currently selected nets.                                                                                                                                 |
| Timing > Path Profile View                              | Displays path delay profiles for the currently selected paths.                                                                                                                                                  |

Table 8-1 Design Vision and IC Compiler Timing Menu Commands (Continued)

| Menu command                                                                     | Action taken                                                                                                                                                                                                         |
|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timing > Check Timing                                                            | Runs the check_timing command, which checks the current design for timing problems such as unconstrained endpoints, no input delay specified, or errors involving multiple clocks.                                   |
| Timing > Report Timing Paths                                                     | Runs the report_timing command. You specify the command options in a dialog box. In the generated timing report, you can click on the intermediate points on the path to highlight them in the layout and schematic. |
| Timing > Report Timing Requirements                                              | Runs the report_timing_requirements command, which reports the timing exceptions that have been set. You specify the command options in a dialog box.                                                                |
| Timing > Report Clock<br>Skew                                                    | Runs the report_clock -skew command, which reports the rise delay, fall delay, and uncertainty of the clock network.                                                                                                 |
| Timing > Report Clock Tree                                                       | Runs the report_transitive_fanout -clock_tree command, which reports the transitive fanout from all the clock source pins and ports, listing the drivers and loads of the clock trees.                               |
| Timing > Report Path<br>Group                                                    | Runs the report_path_group command, which lists the path groups and shows their respective weight and critical range settings.                                                                                       |
| Timing > Report Wire Load<br>(Design Vision window in<br>non-topographical mode) | Runs the report_wire_load command, which reports the characteristics of the wire load models in the design or library.                                                                                               |

## **IC Compiler Layout Window Timing Menu Commands**

Table 8-2 lists and briefly describes the commands available in the Timing menu of the IC Compiler layout window.

Table 8-2 IC Compiler Layout Window Timing Menu Commands

| Menu command        | Action taken                                                                                                                                                   |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timing > Trace Mode | Runs the set_fp_trace_mode command, which marks a design and then loads a subset of the design in trace mode for in-place optimization during design planning. |

Table 8-2 IC Compiler Layout Window Timing Menu Commands (Continued)

| Menu command                           | Action taken                                                                                                                                                                                                                              |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timing > Timing and Optimization Setup | Opens an interactive dialog box that lets you set a wide range of timing and optimization options such as synthesis design rules, cost priority, high-fanout synthesis options, power optimization parameters, and extraction parameters. |
| Timing > Set SI Options                | Opens a dialog box that lets you set the crosstalk analysis and optimization options, including whether to enable crosstalk prevention and whether to consider delta delay, static noise, minimum delta delay, and timing windows.        |
| Timing > Static Noise<br>Analysis      | Opens a static noise analysis window that displays the victim nets, aggressor nets, and noise parameters such as slack, peak noise, and individual aggressor noise contribution.                                                          |
| Timing > Write Parasitics              | Runs the write_parasitics command. A dialog box lets you specify the parameters for the generated file, including the format (SPEF or SBPF) and file name.                                                                                |
| Timing > Color By Delta<br>Delay       | Changes the layout view to display a color-coded map of crosstalk delta delays on nets.                                                                                                                                                   |
| Timing > Color By Static Noise         | Changes the layout view to display a color-coded map of crosstalk static noise values on nets.                                                                                                                                            |
| Timing > Color By Imported Paths       | Changes the layout view to display a color-coded map of timing paths in the design. You import one or more report_timing path reports from a file or by copying and pasting into a dialog box.                                            |
| Timing > New Timing<br>Analysis Window | Opens a new timing analysis window containing a list of timing paths in table form, from which you can generate schematics, histograms, reports, and path delay profiles.                                                                 |

## **Path Slack Histogram**

A path slack histogram shows the distribution of slack values for timing paths in the design. To generate a path slack histogram, use the Timing > Path Slack or Timing > Endpoint Slack menu command in the Design Vision main window or the IC Compiler timing analysis window, or use the equivalent toolbar buttons shown in Figure 8-3. Executing the command opens a dialog box in which you can enter the analysis options, as shown in Figure 8-4.



Figure 8-4 Path Slack Histogram Dialog Box

Path slack histograms and endpoint slack histograms are quite similar. Both show the numbers of paths falling within specified ranges of slack values. These are the differences:

- The path slack histogram lists "from-to" paths, possibly including multiple paths to the same endpoint. The number of paths per endpoint (Nworst paths) displayed and the total number of paths per path group (Max paths) displayed are specified in the dialog box.
- The endpoint slack histogram lists all timing path endpoints in the design, showing only the single worst slack per endpoint.

Figure 8-5 shows an example of a path slack histogram.



Figure 8-5 Path Slack Histogram

The bars of the histogram show the number of paths that fall into eight ranges (eight bins) of slack values. The leftmost bin, which contains 15 paths, is displayed in red because the slack is negative. The bins with positive slack are displayed in green. The currently selected bin is highlighted in yellow. The slack values, startpoints, and endpoints of the paths in the selected bin are listed in the table on the right, sorted by slack.

To sort the list, click on the applicable header at the top of the table. To get detailed information about a path in the list, right-click it and choose Path Schematic, Path Inspector, Timing Paths Report, or Properties. To select a path in the list, click on it; this highlights the path in the list, in the schematic view, and in the layout view.

## **Path Inspector**

The path inspector is a tool that displays detailed information about a selected path, including a complete path schematic, clocking information, and timing information. A series of tabs lets you select the type of information you want to examine such as path element tables, a bar-graph delay profile, or path element list. Figure 8-6 shows a typical path inspector window.

Figure 8-6 Path Inspector



In Design Vision, the path inspector is a separate window with its own command menu. In the IC Compiler GUI, the path inspector is a window within the timing window and is under the control of the timing window's command menu. However, operation of the path inspector is very similar between Design Vision and the IC Compiler GUI.

The status panel at the top of the path inspector shows the "from" (startpoint) object, "to" (endpoint), delay type (max or min), and slack value. The "footprint" button in the status panel, when depressed, causes the contents of the path inspector window to "follow" the current selection. In other words, selecting a new path immediately updates the contents of the path inspector. Otherwise, you can manually update the path inspector by clicking the Load Selected button.

In the tab panel section, you can click on a tab to display the desired information about the path. Figure 8-7 and Figure 8-8 show the types of information you can display.

Figure 8-7 Path Inspector Tabs



Figure 8-8 Path Inspector Tab Panel View Examples



To use the path inspector, first select the path of interest, for example, by choosing Select > Paths From/Through/To or by selecting from a path list in a slack histogram. Then, in Design Vision, choose Timing > Path Inspector. In the IC Compiler timing window, choose Path Inspector > Show Path Inspector. This opens a new path inspector window.

#### **Path Schematic**

The schematic in the path inspector shows the clock launch path and clock capture path. The launch path includes the circuit elements from the input port of the design to the clock pin at the data launch point. Similarly, the capture path shows the circuit elements leading up to the clock pin at the data capture point.

You can choose to display or not display the data path, launch path, and capture path by checking or unchecking the boxes at the bottom of the path schematic. You can also add or remove a colored, point-to-point overlay line to indicate the data path, launch path, or capture path by clicking the purple, yellow, or blue button at the bottom. By default, the data path highlight line is displayed in purple and the others are not. See Figure 8-9.

Figure 8-9 Path Schematic in Path Inspector



If the schematic includes the clock reconvergence pessimism (CRP) common point in the launch and capture paths, that point is highlighted with a red dot. You can turn on or turn off the display of this dot by clicking the red button at the bottom.

To get more information about any pin, cell, or net in the schematic, rest the mouse pointer on that object. A pop-up InfoTip displays information such as the object name, capacitance, transition arrival time, and slack.

#### **Path Element Tables**

A path element table is a detailed listing of elements in a data path, launch path, or capture path. A path element table for a data path is shown in Figure 8-10.

Figure 8-10 Path Element Table for a Data Path



To display a path element table, use the tabs in the tab panel section of the path inspector as follows:

- Clock > Launch Network Elements for the launch path
- Clock > Capture Network Elements for the capture path
- Data Path > Path Element Table for the data path

By default, elements are listed in path order, from startpoint to endpoint for a data path, or from input port to launch/capture clock pin for a launch path or capture path. To sort the table according to some other criterion such as incremental delay or capacitance, click on the

applicable header in the table. An additional click on the same header button resorts the path list in ascending or descending order. You can resize the header buttons horizontally to adjust the widths of the display fields.

In a data path element table, a pull-down menu at the top of the list lets you specify whether to list nets only, input pins only, output pins only, or some combination of these path elements.

You can select an object in the list by clicking on it. The selected row is highlighted and the object is also highlighted in any visible path schematic, design schematic, or layout view.

## **Path Delay Profiles**

A path delay profile shows the cell-by-cell and net-by-net distribution of delay along a path in the form of a bar graph, allowing you to visualize the relative importance of different cells and nets contributing to the total delay. To view a delay profile, choose the Data Path > Delay Profile tabs in the tab panel section of the path inspector. See Figure 8-11.

Figure 8-11 Hierarchical Path Delay Profile



The types of path profiles are: hierarchical, leaf-level pin-to-pin delay, leaf-level cell and net delay, and aggregate cell/net delay. The initial (default) plot is hierarchical. To change the profile type, use the pull-down menu above the graph.

In the bar at the top, each colored segment shows the path delay contribution of each top-level cell and net in the path, starting at the left for the path startpoint and ending at the right for the path endpoint. The individual, color-coded segments are displayed below the full-path profile. The columns adjacent to the plot show the local pin name, delay contribution, edge type (r for rise or f for fall), the signal direction with respect to the pin (in or out), and the full name of the pin.

The default display is a hierarchical profile. The bar at the top shows the top-level cell delays. You can use the plus [+] and minus [–] buttons to traverse the hierarchy and view the delays at different levels.

To view a flat profile instead, choose the Flat tab. In that case, all the leaf-level delays are displayed in the top bar. When you expand the view by clicking the plus [+] button, the individual delays from all hierarchical levels are displayed below it, as shown in Figure 8-12.



Figure 8-12 Flat Path Delay Profile

You can select an pin in the list by clicking on it. The selected pin is highlighted in the list and also in any visible path schematic, design schematic, or layout view.

## **Timing Analysis Driver**

The timing analysis driver is a GUI panel that lists the timing paths having the worst slack in spreadsheet form. You can sort, filter, and modify the data in the table and examine any particular path in detail using report timing reports, schematics, or the path inspector.

To open a timing analysis driver panel in Design Vision, choose Timing > Timing Analysis Driver. In the IC Compiler main window, choose Window > New Timing Analysis Window, or from the IC Compiler layout window, choose Timing > New Timing Analysis window. A dialog box lets you choose which paths to display. See Figure 8-13.

Figure 8-13 Timing Analysis Driver Path Selection Dialog Box



By default, the timing analysis driver lists the 20 worst-slack maximum-delay (setup) paths per clock group, listing no more than one path per endpoint. In the dialog box, make any desired changed to the default listing parameters. You can use either "Load paths from options" and fill in the fields of the dialog box, or choose "Load paths from command" and select or enter a command to get exactly the paths that you want, such as <code>get\_selection</code> or <code>get\_timing\_paths</code>. Click OK to close the dialog box and generate the path list.

#### Note:

The Design Vision and IC Compiler timing analysis driver panels are slightly different. The Design Vision timing analysis driver panel is described here, but almost all the features described are the same in the IC Compiler GUI.

Figure 8-14 shows an example of a timing analysis driver panel.

Figure 8-14 Timing Analysis Driver Panel



The text box at the very bottom shows the <code>get\_timing\_paths</code> command used to generate the list of paths. The table shows the following characteristics of each path: Slack, Startpoint Pin Name, Endpoint Pin Name, Path Group, Endpoint Clock Skew, Arrival, Required, Startpoint Clock Name, and Endpoint Clock Name.

By default, the paths are listed in order of increasing slack. To sort the listed paths by some other parameter, click the corresponding header button. An additional click on the same header button resorts the path list in ascending or descending order. You can resize the header buttons horizontally to adjust the widths of the display fields.

To select a path, click on its row in the table. The row is highlighted in blue and the selected path is also highlighted in any displayed design schematic or layout view. The Shift and Ctrl keys work in the conventional manner to allow multiple selection of table entries.

The buttons along the bottom let you perform the following actions:

- Schematic: Open a new path schematic window showing the selected path or paths.
- Inspector: Open a path inspector window to get more information about the selected path.
- Histogram: Generate a histogram for the data in one column of the timing path table.

- Report: Generate a timing report (report\_timing command) for the selected path.
- Export: Save the whole timing path table into an ASCII file, one line per path, with column data delimited by commas. The file can be read into any spreadsheet program.
- Columns: Specify the types of data displayed in the columns of the timing path table and the ordering of those columns.
- Reload Paths: Load a new set of paths from the design that meet the criteria that you specify with the get timing paths command or by filling in the dialog box options.

Figure 8-16 shows an example of a path schematic, a path slack histogram, and a timing report opened from the timing analysis driver.

Figure 8-15 Analysis Windows Opened From Timing Analysis Driver



To control the types of parameters shown in the timing analysis driver table and their ordering across the table, click the Columns button. This opens the Show and Order Columns dialog box. See Figure 8-16.



Figure 8-16 Show and Order Columns Dialog Box for Timing Paths

The list on the right shows the path parameters currently displayed in the table, in order from leftmost column to rightmost column. To control their order across the table, select the desired parameters and then click the up and down arrows to move those parameters within the list. The list on the left shows all the possible path parameters that are not currently displayed. To change the displayed parameters, select the applicable parameters and use the left and right arrow buttons to remove or add entries in the "Visible columns" list. Then click OK.

In the report\_timing report window, the incremental timing points are highlighted in blue. You can click on any of these points to display a schematic of the design with the timing point highlighted. In Figure 8-17, the timing point U205/Z is highlighted.

Figure 8-17 Design Schematic Window Opened From Timing Report

# 9

## Timing in Latch-Based Designs

A latch is a simple, 1-bit level-sensitive memory device. In simulation, a signal holds its value until the output is reassigned. In hardware, a latch implements this holding-of-state capability. Time borrowing can be used in latch-based designs to balance the slack in successive latch path stages, and thereby optimize near-critical paths and reduce delay costs.

This chapter includes the following sections:

- Time Borrowing in Latch-Based Designs
- Constraining a Latch-Based Design
- Path Timing Report With Borrowing
- Latch-Based Time-Borrowing Example

## **Time Borrowing in Latch-Based Designs**

The analysis tool uses time borrowing to analyze the timing of level-sensitive latches. A latch is transparent for the duration of the active clock pulse, meaning that the data appearing on the input of the latch is propagated directly to the output of the latch. If the path leading to the data pin of a latch is too long, one cycle can borrow from the next cycle to extend the time during which the latch is enabled.

### A Simple D Latch

To illustrate the processes involved in time borrowing, this section uses a simple D latch. This section includes example VHDL and Verilog code for the D latch and shows the inference report generated when either set of code is compiled.

When you infer a D latch, make sure you can control the gate and data signals from the top-level design ports or through combinational logic. Controllable gate and data signals ensure that simulation can initialize the design.

Example 9-1 gives the VHDL code for a D latch.

#### Example 9-1 VHDL Template for a D Latch

Example 9-2 gives the Verilog code for a D latch.

#### Example 9-2 Verilog Template for a D Latch

```
module d_latch (GATE, DATA, Q);
    input GATE, DATA;
    output Q;
    reg Q;

always @(GATE or DATA)
    if (GATE)
        Q = DATA:
end module
```

An inference report contains the information the code compiler passes on to the analysis tool about the inferred devices.

The following table shows the verbose inference report generated for a D latch, using either the VHDL code in Example 9-1 or the Verilog code in Example 9-2. Although the coding styles differ, both inferences are the same, and thus they produce the same inference report.

Table 9-1 Inference Report for a D Latch

| Register name | Туре  | Width | Bus | МВ | AR | AS | SR | ss | ST |
|---------------|-------|-------|-----|----|----|----|----|----|----|
| Q_reg         | Latch | 1     | _   | _  | N  | N  | _  | _  | _  |

```
Q_reg
----
reset/set: none
```

For details to help you understand the inference report for Verilog code or VHDL code, see the HDL Compiler documentation.

## **About Time Borrowing**

If the path leading to the data pin of a latch is too long, time can be borrowed from the next cycle to enable the latch for a certain duration. This section uses the two-stage latch-based design shown in Figure 9-1 on page 9-4 to explain the concepts that underlie the time-borrowing process.

Each stage of the design consists of a block of combinational logic with a latch on either side. The startpoint of a stage is defined by the latch that precedes the combinational logic block; the endpoint of a stage is defined by the latch that follows the combinational logic block. Thus, as indicated in the bottom illustration of Figure 9-1, the endpoint of one stage is also the startpoint of the next stage.

In the bottom illustration of Figure 9-1, the dotted line labeled "Active Edge...at Startpoint" denotes the edge of the clock that renders the startpoint latch transparent—Latch1 in the top illustration of the same figure is the startpoint latch.

The dotted line labeled "Active Edge at Endpoint" denotes the edge of the clock before which the data should stabilize at the input of the endpoint latch—Latch2 in the top illustration of the figure is the endpoint latch.

Data In Data Out Combina-Combinational tional Latch1 Latch2 Latch3 Logic Logic Clock1 Clock2 Stage1 Stage2 Time Taken for Stage1 Time Borrowed From Endpoint Clock1 Clock2 Active Edge at 0 10 20 30 Endpoint (Stage2) Active Edge at Reference Edge at Endpoint Reference Edge Endpoint (Stage2) Active Edge and at Endpoint Reference Edge at

Figure 9-1 General Structure of a Latch-Based Design

The reference edge at startpoint—marked by the same dotted line that shows the active edge at startpoint—is the edge of the clock that serves as the reference base for making timing calculations for the startpoint latch, Latch1. The reference edge at endpoint is the edge of the clock that serves as the reference base for making timing calculations for the endpoint latch, Latch2.

In this design, the combinational logic block between Latch1 and Latch2 has more delay than the delay between Latch2 and Latch3. To resolve this discrepancy, the first stage can borrow time from the second clock cycle. In this event, the second clock cycle is left with less time to accommodate the combinational logic block between Latch2 and Latch3.

Startpoint

Depending on the requirement, the combinational block between Latch1 and Latch2 can utilize the time period from the reference edge at startpoint (Latch1) to the line labeled AB; this is the borrowed time Stage1 gets. Initially, this is 50 units of the time used (whether milliseconds, nanoseconds, or another unit of time). Giving Stage1 the borrowed time results in the next combinational block—that is, Stage2— having the time period from AB onward. Thus, the starting point for the Stage2 combinational block becomes AB.

## **Balancing Relative Slacks**

This section describes how to balance the relative slacks in two sides of a latch in order to cause near-critical paths to be optimized and reduce costs.

This section includes the following topics:

- Determining Relative Slack
- · Optimizing Near-Critical Paths
- Reducing Delay Costs

### **Determining Relative Slack**

The relative slack of a path is the absolute (negative) slack of the path group to which the path in question belongs, minus the (negative) slack of the critical path in the same path group. Unless the path in question is the critical path of the path group, the relative slack will always be a negative number. If the path in question is the path group's critical path, then the relative slack will be zero (0). The equation in Example 9-3 shows how relative slack is determined.

#### Example 9-3 Equation Used to Ascertain Relative Slack

```
relative_slack =
  (absolute slack of the path group) - (slack of the critical path of the path group)
```

## **Optimizing Near-Critical Paths**

This section explains the relative slacks of both stages of the example latch-based design, based on the initial amount of time borrowed by Stage1 from the Clock2 cycle—that is, before the relative slacks are balanced. Then it explains how to balance these relative slacks.

#### Relative Slacks of Both Stages Before Balancing

In considering the latch-based design example for whose two stages the relative slacks are shown before balancing, in Figure 9-2 on page 9-7, assume the following values to be true:

The time borrowed from the endpoint in Stage1 is 50.

- The critical path's slack in the path group for Clock1 is -70.
- The critical path's slack in the path group for Clock2 is -40.

In this scenario, neither Stage1 nor Stage2 is the critical path.

Given the equation in Example 9-3 on page 9-5 that is used to determine relative slack and the values used in the example latch-based design, here is how the relative slacks resolve for both stages:

Relative slack in Stage1 is

$$0 - 40 = 40$$

#### where

- 0 is the absolute slack
- -40 is the critical path's slack
- 40 is the relative slack
- Relative slack in Stage2 is

$$-40 - 70 = 30$$

#### where

- -40 is the absolute slack
- -70 is the critical path's slack
- 30 is the relative slack

The Stage1 relative slack, which is 40, and the Stage2 relative slack, which is 30, are not balanced. To achieve an absolute slack of 0 for Stage1, the absolute slack for Stage2 must be increased—that is, worsened. The tool will not attempt to optimize the Stage1 path even if a critical range is set. Figure 9-2 on page 9-7 shows both stages before the relative slack is balanced.

Clock1

Clock2

Slack = 0

Relative Slack 40

Stage1

Stage2

Stage2

Latch2

Combo
Logic

Latch3

Latch3

Latch3

Slack = -40

Relative Slack 30

Figure 9-2 Both Stages Before Relative Slack Balancing (for Optimizing Near-Critical Paths)

#### **Relative Slacks After Balancing**

To attempt to balance the relative slacks, the time borrowed from the Clock2 cycle and given to Stage1 is reduced to 45. This produces an absolute slack of –35 for Stage2 and an absolute slack of –5 for Stage1.

Given the equation shown in Example 9-3 on page 9-5, used to ascertain relative slack, and the new absolute slack values, here is how the relative slacks now resolve for both stages:

Relative slack in Stage1

$$-5$$
  $-40$  = 35

#### where

- 5 is the absolute slack
- –40 is the critical path's slack
- 35 is the relative slack
- Relative slack in Stage2 is

$$-35 - -70 = 35$$

#### where

- -35 is the absolute slack
- -70 is the critical path's slack
- 35 is the relative slack

This modification of the amount of time borrowed results in Stage1 and Stage2 relative slacks that are balanced. The tool performs this resolution automatically. Figure 9-3 depicts the result of balancing the relative slacks.

Figure 9-3 Both Stages After Balancing Relative Slacks (for Optimizing Near-Critical Paths)



Given that Stage1 now has a negative slack—that is, -5—if you set a critical range that is more than 5, the tool will optimize the path. Therefore, balancing relative slacks helps in optimizing near-critical paths.

## **Reducing Delay Costs**

This section explains how to reduce delay costs by balancing the relative slacks of both stages of a latch-based design.

#### **Relative Slacks Before Balancing**

In considering the latch-based design example for whose two stages the relative slacks are shown in Figure 9-2 before they are balanced, assume the following values to be true:

- The time borrowed from the endpoint in Stage1 is 60.
- The critical path in the path group for Clock1 has a slack of -70.
- The critical path in the path group for Clock2 has a slack of -40.

Assume, also, that the slacks in some of the near-critical paths in the Clock1 path group are -60, -50. and -40.

Here is how the relative slacks resolve for both stages:

Relative slack in Stage1

$$-0$$
  $-40$  = 40

#### where

- 0 is the absolute slack in Stage1
- –40 is the critical path's slack in path group Clock2
- 40 is the relative slack
- Relative slack in Stage2 is

$$-70 - 70 = 0$$

#### where

- -70 is the absolute slack in Stage2
- -70 is the critical path's slack in path group Clock2
- 0 is the relative slack

As shown in Figure 9-4, the relative stack in Stage1 is -40 and the relative slack in Stage2 is 0. This results in Stage2 being the critical path of its path group. The resulting delay cost is 110, given a critical path slack in path group Clock1 of 70 and a critical path slack in path group Clock2 of 40.

Figure 9-4 Both Stages Before Balancing Relative Slacks (for Reducing Delay Costs)



#### **Relative Slacks After Balancing**

In an attempt to balance the relative slacks of both stages, the time borrowed by Stage1 from the Clock2 cycle is reduced from 60 to 35. Ultimately, this reduces the delay costs from 110 to 100, as shown in Figure 9-5 on page 9-10.

Reducing the time borrowed by Stage1 produces the following balanced relative slacks for both stages:

Relative slack in Stage1

$$-25 - -40 = 15$$

#### where

- 25 is the absolute slack in Stage1
- -40 is the critical path's slack
- 15 is the relative slack
- Relative slack in Stage2 is

$$-45 - 70 = 0$$

#### where

- -45 is the absolute slack in Stage2
- -60 is the critical path's slack
- 15 is the relative slack

The critical slack in path group Clock1 is now 60, and the critical path's slack in the path group of Clock2 is now 40.

The relative slack of both stages is now 15, as shown in Figure 9-5.

Figure 9-5 Result of Balancing Relative Slacks for Reducing Delay Costs



As is evident from Figure 9-5, if the relative slacks had not been balanced, the path in Stage2 would have been treated as the critical path and the near-critical path with a slack of -60 would not have been optimized. Balancing the relative slacks causes the previous near-critical path to become the critical path, subjecting it to optimization, which is desirable. Moreover, you can easily optimize the previous critical path by setting the proper critical range.

# **Constraining a Latch-Based Design**

Design Compiler assumes that all external registers are positive edge flip-flops unless they are explicitly created as level-sensitive latches.

You use the following commands to infer external registers:

```
    set_input_delay delay_value \
        -clock clock_name input_port
    set_output_delay delay \
```

-clock clock name output port

These commands set the input delay on input and output ports relative to a clock cycle. The *delay\_value* argument specifies the path delay, expressed in units of time consistent with the technology library used during optimization. The *clock\_name* argument specifies the clock the stipulated delay pertains to. The *input\_port* argument specifies the input port in the current design to which *delay\_value* is assigned. The *output\_port* argument specifies the output port in the current design to which *delay\_value* is assigned.

Specify the <code>-level\_sensitive</code> option for these commands to define external registers as active-high level-sensitive latches, as shown in the following examples:

```
prompt> set_input_delay 4 -clock CLK2 -level_sensitive [all_inputs] Specifying the -level_sensitive option allows the tool to derive the setup and hold relationships for paths from this port, with the presumption that it is a level-sensitive latch.
```

Specify both the <code>-level\_sensitive</code> and <code>-clock\_fall</code> options to define external registers as active-low level-sensitive latches, as shown in the following example:

Specifying the -clock\_fall option stipulates that the delay is relative to the falling edge of the clock.

## **Creating Non-Overlapping Clocks**

This section describes non-overlapping clocks, which are used by most two-phase designs. It also explains two-phase designs.

You use the <code>create\_clock</code> command to create two non-overlapping clocks. Here are examples showing how to specify the <code>create\_clock</code> command:

### What Are Two-Phase Designs?

Most latch-based designs use two-phase non-overlapping clocks. These designs are referred to as two-phase designs.

The following requirements apply to two-phase designs:

- All paths originating at a phase-1 latch should terminate at a phase-2 latch. A phase-1 latch is a latch clocked by a phase-1 clock.
- All paths originating at a phase-2 latch should terminate at a phase-1 latch.

Consequently, successive stages of latches should be clocked by alternative clocks, as illustrated in Figure 9-6 on page 9-12.

Figure 9-6 Two-Phase Design



# What Are Non-Overlapping Clocks?

Non-overlapping clocks are clocks that don't make a latch transparent simultaneously. Figure 9-7 shows two non-overlapping clocks, Clock1 and Clock2.

Figure 9-7 Non-Overlapping Clocks



# **Path Timing Report With Borrowing**

Figure 9-8 shows a latch-based design using a simple two-phase clocking scheme. The timing report follows the explanation of Figure 9-8.

Figure 9-8 Latch-Based Design



U1, U2, and U3 are positive level-sensitive latches (active when G=1). P1 and P2 are combinational logic paths. Assuming a library setup time of zero for the latches and path lengths of P1 = 8.92 and P2 = 0.77, it appears that there is a violation at U2. Path P1 is longer than the rising edge of phi2. However, the latch enable time of phi2 is 5, and path P1 can use this time if path P2 has enough slack.

#### Note:

Although one latch-to-latch path might be greater than the period of the clock, any two successive paths must be less than twice the period for a single-phase design.

Example 9-4 shows the timing report for the latch-based design. In this report, **bold** type helps you locate the time-borrowing information.

### Example 9-4 Timing Report for a Latch-Based Design

```
*********
Report: timing
      -path short
      -delay max
      -max_paths 1
Design: time_borrow
Version: Y-2006.06
Date :Mon May 1 2006
**********
Wire Loading Model Mode: enclosed
 Startpoint: U1 (positive level-sensitive latch clocked by Phi1)
 Endpoint: U2 (positive level-sensitive latch clocked by Phi2)
 Path Group: Phi2
 Path Type: max
                                   Incr Path
 Point
                            0.00 0.00
0.00 0.00
0.00 0.00 r
0.57 0.57 r
 clock Phil (rise edge)
 clock network delay (ideal)
 U1/G (LATCH)
 U1/Q (LATCH)
                                           8.92 r
 U2/D (LATCH)
                                  8.35
 data arrival time
                                           8.92
 clock Phi2 (rise edge)
clock network delay (ideal)
                                  5.00
                                           5.00
                                           5.00
                                   0.00
                                           5.00 r
                                   0.00
 time borrowed from endpoint
                                   3.92
                                             8.92
 data required time
                                             8.92
                  -----
 data required time
                                            8.92
 data arrival time
                                            -8.92
_____
 slack (MET)
                                             0.00
 Time Borrowing Information
 Phi2 pulse width
                                  5.00
 library setup time
                                  -0.46
```

| max time borrow actual time borrow                                                                             | 4.54<br>3.92 |       |   |
|----------------------------------------------------------------------------------------------------------------|--------------|-------|---|
| tartpoint: U2 (positive level-sensitive Endpoint: U3 (positive level-sensitive Path Group: Phi1 Path Type: max |              |       |   |
| Point                                                                                                          |              | Path  |   |
| clock Phi2 (rise edge                                                                                          | 5.00         | 5.00  |   |
| clock network delay (ideal)                                                                                    | 0.00         | 5.00  |   |
| time given to startpoint                                                                                       | 3.92         | 8.92  |   |
| U2/D (LATCH)                                                                                                   | 0.00         | 8.92  | r |
| U2/Q (LATCH)                                                                                                   | 0.53         | 9.45  | r |
| U3/D (LATCH)                                                                                                   | 0.24         | 9.69  | f |
| data arrival time                                                                                              |              | 9.69  |   |
| clock Phi1 (rise edge)                                                                                         | 10.00        | 10.00 |   |
| clock network delay (ideal)                                                                                    | 0.00         |       |   |
| U3/G (LATCH)                                                                                                   | 0.00         | 10.00 | r |
| time borrowed from endpoint                                                                                    | 0.00         | 10.00 |   |
| data required time                                                                                             |              | 10.00 |   |
| data required time                                                                                             |              | 10.00 |   |
| data arrival time                                                                                              |              | -9.69 |   |
| slack (MET)                                                                                                    |              | 0.31  |   |
| Time Borrowing Information                                                                                     |              |       |   |
| Phi1 pulse width                                                                                               | 5.00         |       |   |
| library setup time                                                                                             | -0.49        |       |   |
| max time borrow                                                                                                | 4.51         |       |   |
| actual time borrow                                                                                             | 0.00         |       |   |

For a positive level-sensitive latch, Design Compiler uses the rising edge as the reference edge.

- For the U1 to U2 path, a setup violation appears at U2, because the signal arrives at 8.92 and the clock arrives at 5.00. Because the U2 latch is transparent, 3.92 ns can be borrowed from the following U2 to U3 path and still meet the setup time at the U2 falling edge. The first timing path shows 3.92 ns being borrowed. This is reported in the timing report for the first path.
- For the U2 to U3 path, time must be added to compensate for the time borrowed, so 3.92 ns is added to the U2 launch time. This is reported in the timing report for the second path. Because the P2 path has enough slack, neither path is a violation.

In some cases, you might not want time borrowing enabled for all or part of a design. You can limit or disable time borrowing by using the set\_max\_time\_borrow command. The syntax is

```
set_max_time_borrow time_limit object_list
```

The set\_max\_time\_borrow command places a max\_time\_borrow attribute of a specified value on clocks, latch cells, data pins, or clock (enable) pins to constrain the amount of time borrowing for level-sensitive latches. To meet delay targets, time borrowing prevents automatic use of all or part of the enabling clock pulse on a latch. If the attribute is set on a cell and the cell is replaced during optimization, the attribute is moved from the cell to the enable pin.

To prevent time borrowing, specify a time limit of 0.0.

The max\_time\_borrow attribute is ignored when it is placed on clocks that affect no latches, on pins other than latch enable pins, and on cells other than latches.

The increase that can occur in timing analysis runtime for multifrequency designs containing level-sensitive latches occurs because the tool considers all dominant pulse relations for paths where there can be time borrowing. These considerations can be time-consuming if the clocks are of very different frequencies because there are numerous pulse relations between such clocks.

To prevent time borrowing for the entire design, enter the following command:

```
prompt> set_max_time_borrow 0.0 [all_clocks]
```

To limit time borrowing to 1.2 units for U1/G and U2/G:

```
prompt> set_max_time_borrow 1.2 {U1/G U2/G}
```

To undo a set\_max\_time\_borrow command, use the remove\_attribute command. For example, to undo the previous commands, enter the following command sequence:

```
prompt> remove_attribute [all_clocks] max_time_borrow
prompt> remove_attribute {U1/G U2/G} max_time_borrow
```

# **Latch-Based Time-Borrowing Example**

This section provides an example design for a linear block encoder. The design is composed of the following parts:

- Linear Block Encoder
- Noisy Channel
- Linear Block Decoder for Single Bit Error

The linear block encoder and decoder design, presented in this section, is a latch-based design that uses time borrowing. This section describes the design before giving the code that implements it.

This section includes these topics:

- Linear Block Encoder and Decoder
- Noisy Channel
- · Linear Block Decoder for Single-Bit Error
- Linear Block Encoder and Decoder Implementation
- · Setting Constraints on the Linear Block Encoder

#### **Linear Block Encoder and Decoder**

Example 9-10 on page 9-20 gives the VHDL code that implements the linear block encoder and decoder. Before you review the code, read this background information about the encoder and decoder implementation.

Here is how the linear block encoder and decoder design works: Each 4-bit message word, denoted as a row vector or 4-tuple

$$D = (d1, d2, d3, d4)$$

is transformed to a code word C, 7 bits in length

```
(C=(c1,c2,...c7))
```

To achieve this, the linear block encoder adds 3 parity bits to each 4-bit message.

The value of C is generated from the matrix multiplication equation in Example 9-5.

# Example 9-5 Equation i: Matrix Multiplication C = DG ...(i)

where G is the generator matrix of the code.

Example 9-6 shows the generator matrix equation.

### Example 9-6 Equation ii: Generator Matrix

```
G = [14 \mid P]4x7 ...(ii)
```

where

- 14 is an identity matrix of order 4.
- P is an arbitrary matrix of order 4 by 3, known as a parity matrix.

The VHDL sample code includes these processes:

P\_MATRIX\_IN

This process reads the P matrix and generates the G matrix and the HT matrix. The HT matrix is a transposition of the parity check matrix.

• DATA READ

This process reads in the 4-bit message word.

LINEAR\_BLOCK\_CODE

This process generates the Linear Block Code (C) according to equation i, the matrix multiplication equation in Example 9-5 on page 9-18.

# **Noisy Channel**

The noisy channel adds a 1-bit error to the code word C and generates the signal R. The signal is received by the decoder in the format represented by Equation iii in Example 9-7.

# Example 9-7 Equation iii: Signal R

```
R = C + E ...(iii)
```

where E is a 7-bit word with any one of the first 4 bits equal to 1 and all other bits equal to 0. The bit that is set to 1 is the erroneous bit.

# **Linear Block Decoder for Single-Bit Error**

A parity check matrix H is associated with the generator matrix G. Example 9-8 shows the parity check matrix.

### Example 9-8 Equation iv: Parity Check Matrix

```
H = [PT | I3]3x7 ...(iv)
```

In the equation given in Example 9-9, where S is a 3-bit word known as the error syndrome of R for nonzero E, S is one of the rows of the matrix H<sup>T</sup>, depending on the erroneous bit of R.

### Example 9-9 Equation v: Error Syndrome

```
S = RHT ...(v)

S = 0, if E = 0;
```

That is, if there is an error in the i*th* bit in R, then the syndrome is the i*th* row of the H<sup>T</sup> matrix. Thus, by comparing the syndrome with the rows of H<sup>T</sup>, the error can be detected and the data word D can be recovered.

The SYNDROME\_GEN process in the VHDL code shown in Example 9-10 generates the syndrome according to equation v, the error syndrome equation.

The DECODER process compares the syndrome with the rows of H<sup>T</sup> and recovers D.

### **Linear Block Encoder and Decoder Implementation**

This section includes these parts:

- VHDL Code
- Setting Constraints on the Linear Block Encoder

### **VHDL Code**

Example 9-10 shows the VHDL code that implements the linear block encoder and decoder described in the preceding sections.

```
library IEEE, SYNOPSYS, WORK;
use IEEE.std_logic_1164.all;
use SYNOPSYS.attributes.all;
use IEEE.std_logic_arith.all;
use IEEE.std_logic_misc.all;
use WORK.MATRIX_RELATED.all;
entity LINEAR DECODER is
 port ( DATA_IN : in DATA_WORD;
         ERROR_WORD : in CODE_WORD;
         P_MATRIX : in CHECK_MATRIX;
         CLOCK1, CLOCK2, WRITE_ENAB : in std_logic;
         DATA_OUT : out DATA_WORD );
end LINEAR_DECODER;
architecture BEHAVIORAL of LINEAR_DECODER is
signal D : DATA_WORD;
signal P : CHECK_MATRIX;
signal C, E, R, R1 : CODE_WORD;
signal S : SYNDROME_WORD;
signal G : GENERATOR_MATRIX;
signal H_tran : PARITY_CHECK_MATRIX_TRAN;
```

```
begin
  P MATRIX IN : process (P MATRIX, WRITE ENAB)
  variable G_temp : GENERATOR_MATRIX;
  variable H_tran_temp : PARITY_CHECK_MATRIX_TRAN;
  begin
    if(WRITE\_ENAB = '1') then
      P <= P_MATRIX;
      E <= ERROR_WORD;</pre>
      for I in K downto 1 loop
        for J in K downto 1 loop
          if (I = J) then
            G_{temp}(I)(J) := '1';
          else G_{temp}(I)(J) := '0';
          end if:
        end loop;
        for J in N downto K+1 loop
          G_{temp}(I)(J) := P_{MATRIX}(I)(J-K);
        end loop;
      end loop;
      for I in K downto 1 loop
        for J in N-k downto 1 loop
           H_{tran_{temp}(I)(J)} := P_{MATRIX(I)(J)};
        end loop;
      end loop;
      for I in N downto K+1 loop
        for J in N-K downto 1 loop
          if (I-K = J) then
            H_tran_temp(I)(J) := '1';
          else H_tran_temp(I)(J) := '0';
          end if;
        end loop;
      end loop;
      G <= G_temp;</pre>
      H_tran <= H_tran_temp;</pre>
    end if;
  end process P_MATRIX_IN;
```

```
DATA_READ : process ( DATA_IN, CLOCK1 )
begin
  if (CLOCK1 = '1') then
    D <= DATA_IN;</pre>
  end if;
end process DATA_READ;
LINEAR_BLOCK_CODE : process ( D, CLOCK2 )
variable C_temp : CODE_WORD;
begin
  if ( CLOCK2 = '1' ) then
    for I in C'range loop
      C_{temp}(I) := '0';
      for J in D'range loop
        C_{temp}(I) := C_{temp}(I) \text{ xor } (D(J) \text{ and } G(J)(I));
      end loop;
    end loop;
    C <= C_temp;</pre>
  end if;
end process LINEAR_BLOCK_CODE;
CHANNEL: process (C, CLOCK1)
begin
  if (CLOCK1 = '1') then
    for I in C'range loop
      R(I) \ll C(I) \times C(I);
    end loop;
  end if;
end process CHANNEL;
```

```
SYNDROME_GEN : process ( R, CLOCK2 )
 variable S_temp : SYNDROME_WORD;
 begin
    if (CLOCK2 = '1') then
      for I in S'range loop
        S_{temp}(I) := '0';
        for J in R'range loop
          S_{temp}(I) := S_{temp}(I)  xor ( R(J)  and H_Tran(J)(I) );
        end loop;
      end loop;
      S <= S_temp;
     R1 \ll R;
    end if;
 end process SYNDROME_GEN;
 DECODER: process (S, CLOCK1, R1)
 variable temp,temp1 : CODE_WORD;
 variable J : integer;
 begin
  if ( CLOCK1 = '1' ) then
   J := 0;
   for I in H_Tran'range loop
      if (S = H_Tran(I)) then
       J := I;
      end if;
    end loop;
    for I in temp'range loop
      if (I = J) then
        temp(I) := '1';
      else
        temp(I) := '0';
      end if;
    end loop;
    for I in R1'range loop
      temp1(I) := temp(I) xor R1(I);
    end loop;
    for I in K downto 1 loop
     DATA_OUT(I) <= temp1(I);</pre>
    end loop;
   end if;
 end process DECODER;
end BEHAVIORAL;
```

```
library IEEE, SYNOPSYS;
use IEEE.std logic 1164.all;
use SYNOPSYS.attributes.all;
use IEEE.std_logic_arith.all;
use IEEE.std logic misc.all;
package MATRIX_RELATED is
  constant K : integer := 4;
  constant N : integer := 7;
  type DATA_WORD is array(K downto 1) of std_logic;
  type CODE_WORD is array(N downto 1) of std_logic;
  type CHECK_WORD is array(N-K downto 1 ) of std_logic;
  type SYNDROME WORD is array (N-K downto 1) of std logic;
   type GENERATOR MATRIX is array (K downto 1) of CODE WORD;
  type PARITY_CHECK_MATRIX_TRAN is array(N downto 1) of
SYNDROME_WORD;
  type CHECK_MATRIX is array(K downto 1) of CHECK_WORD;
end MATRIX_RELATED;
```

Figure 9-9 shows the LINEAR\_DECODER synthesis produced from the code shown in Example 9-10 on page 9-20.

Figure 9-9 LINEAR DECODER Synthesis



# **Setting Constraints on the Linear Block Encoder**

You can use the command sequence shown in Example 9-11 to set constraints for the linear block encoder and decoder.

#### Example 9-11 Setting Constraints on the Linear Block Encoder

```
set_wire_load_min_block_size "05x05"
set_wire_load_model -library "lsi_10k"
set_operating_conditions -library "lsi_10k" "WCCOM"
set_drive drive_of(lsi_10k/IV/Z) [all_inputs]
set_load load_of(lsi_10k/IV/A) [all_inputs]
```

Figure 9-10 shows the two-phase clocks for the linear block encoder and decoder produced by the preceding constraints.

Figure 9-10 Two-Phase Clocks for the LINEAR\_DECO



### report\_timing Command Output

Example 9-12 on page 9-26 shows a portion of the information produced by the following report\_timing command:

```
prompt> report_timing -delay max -max_paths 20
```

### Example 9-12 Report Timing Output Showing Relative Slack Balancing

Information: Updating design information... (UID-85) Automatic time borrowing...

\*\*\*\*\*\*\*\*\*

Startpoint: R\_reg[3] (positive level-sensitive latch clocked

by CLK1)

 ${\tt Endpoint: S\_reg[2] \ (positive \ level-sensitive \ latch \ clocked)}$ 

by CLK2)

Path Group: CLK2 Path Type: max

| Point                                                                                                                          | Incr                          | Path                              |
|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------|
| <pre>clock CLK1 (rise edge) clock network delay (ideal) R_reg[3]/G (LD1P) R_reg[3]/Q (LD1P)</pre>                              | 0.00                          | 9.00<br>9.00<br>9.00 r<br>11.29 f |
| S_reg[2]/D (LD1P) data arrival time                                                                                            | 7.16                          | 18.45 r<br>18.45                  |
| <pre>clock CLK2 (rise edge) clock network delay (ideal) S_reg[2]/G (LD1P) time borrowed from endpoint data required time</pre> | 17.00<br>0.00<br>0.00<br>0.00 | 17.00<br>17.00 r                  |
| data required time<br>data arrival time                                                                                        |                               | 17.09<br>-18.45                   |
| slack (VIOLATED)                                                                                                               |                               | -1.36                             |
| Time-Borrowing Information                                                                                                     |                               |                                   |
| CLK2 pulse width library setup time                                                                                            |                               | 5.00                              |
| max time borrow actual time borrow                                                                                             |                               | 4.40<br>0.09                      |

Point

Example 9-12 Report Timing Output Showing Relative Slack Balancing (Continued)

Incr

Path

Startpoint: S\_reg[2]
(positive level-sensitive latch clocked by CLK2)
Endpoint: DATA\_OUT\_reg[3]
(positive level-sensitive latch clocked by CLK1)
Path Group: CLK1
Path Type: max

| rome                                                                                                                                 | IIICI | racii            |
|--------------------------------------------------------------------------------------------------------------------------------------|-------|------------------|
| clock CLK2 (rise edge) clock network delay (ideal) time given to startpoint S_reg[2]/D (LD1P) S_reg[2]/Q (LD1P)                      |       | 2.09 r           |
| DATA_OUT_reg[3]/D (LD1) data arrival time                                                                                            | 10.32 | 15.30 r<br>15.30 |
| <pre>clock CLK1 (rise edge) clock network delay (ideal) DATA_OUT_reg[3]/G (LD1) time borrowed from endpoint data required time</pre> | 4.25  | 9.00 r           |
| data required time<br>data arrival time -15.30                                                                                       |       | 13.25            |
| slack (VIOLATED)                                                                                                                     |       | -2.05            |

| Time-Borrowing Information |       |
|----------------------------|-------|
|                            |       |
| CLK1 pulse width           | 5.00  |
| library setup time         | -0.40 |
|                            |       |
| max time borrow            | 4.60  |
| actual time borrow         | 4.25  |
|                            |       |

Figure 9-11 summarizes the report\_timing output shown in Example 9-12 on page 9-26. As Figure 9-11 shows, the cost is 3.77—2.41 + 1.36—and the relative slacks in paths II, III and IV are, respectively, 0, 0.36, and 0.11. These relative slacks are almost balanced. Note, however, that the absolute slacks in paths II, III, and IV are not balanced. The absolute slacks are, respectively, -1.36, -2.05, and -1.25.

Slacks in two paths that are in different path groups cannot be compared, but relative slack, which is the measure of the criticality of any path, can always be compared.

Path Group CLK1 CLK1 CLK<sub>2</sub> CLK<sub>2</sub> Critical Slack in Path -1.36-2.41-2.41 -1.36Group Slack in This path -1.36-2.05 2.55 -1.254.96 0 0.36 0.1 Relative Slack in This path PATH I PATH II PATH III PATH IV CLK1 \_ R\_reg[3] DATA\_OUT\_reg[3] S\_reg[2 CLK2.

Figure 9-11 Timing Report Using Automatic Time Borrowing

Figure 9-12 on page 9-29 presents the timing report of the linear encoder and decoder design without the auto time-borrowing feature.

As shown in Figure 9-12, the cost is 5.13—3.77 + 1.36—and the relative slacks in paths II, III and IV are, respectively, 1.36, 0.39, and 0. These relative slacks are not balanced. Note that the absolute slacks in paths II, III, and IV are also not balanced. The absolute slacks are, respectively, -1.36, -2.05, and -1.25.

The disable\_auto\_time\_borrow variable determines whether the report\_timing command and other commands perform automatic time borrowing. When the variable is set to false (the default), automatic time borrowing occurs, which balances the slack along back-to-back latch paths to reduce the overall delay cost. Allocating slack throughout the latch stages can improve optimization results.

When the variable is set to true, no slack balancing occurs during time borrowing. This means that the first paths borrow enough time to meet the constraint until the maximum time borrow value is reached, as set by the set\_max\_time\_borrow command. This behavior is consistent with PrimeTime.

Path Group CLK1 CLK2 CLK1 CLK2 Critical Slack in Path -3.77-1.36-3.77-1.36Group Slack in This path 0 -3.382.55 -1.36Relative Slack in This path 6.32 1.36 0.39 0 PATH I PATH II PATH III PATH IV CLK1 S reg[2 DATA\_OUT\_reg[3] R\_reg[3]

Figure 9-12 Timing Report Without Using Automatic Time Borrowing

### **Results of Use of Automatic Time Borrowing**

Use of automatic time borrowing, as shown in report timing for the example design, reduces the delay cost from 5.13 (3.77 + 1.36) to 3.77 (2.41 + 1.36).

Here are some comparisons of delay cost with and without use of automatic time borrowing:

Without use of automatic time borrowing,

CLK2\_

- The path S-\_reg[3] to DATA\_OUT\_reg[2] with a slack of -3.77 was the critical path in the path group CLK1.
- The path DATA\_OUT\_reg[2] to DATA\_OUT[1] with a slack of -1.36 was the critical path in the path group CLK2.
- The critical slack in group CLK1 is -3.77, and the critical slack in CLK2 is -1.36.

With use of automatic time borrowing,

• The slack in the path from S reg[3] to DATA OUT reg[2] is reduced to -2.41, from -3.77.

- For the path group CLK2, the slack in the path from DATA\_OUT\_reg[2] to DATA\_OUT[1] is reduced to -1.25 from
  - -1.36. The path from R\_reg[3] to S\_reg[1] with a slack of -1.36 is now the critical path in group CLK2. (Without use of automatic time borrowing, this path had 0 slack.)
- The critical slack in CLK1 is -2.41, and the critical slack in CLK2 is -1.36.

Figure 9-13 on page 9-30 shows how automatic time borrowing tried to balance the relative slacks in Paths II, III, and IV, which are shown in Figure 9-11 on page 9-28 and Figure 9-12 on page 9-29.

Figure 9-13 Balancing Relative Slacks by Reducing Borrowed Time





# Static Timing Delay Calculation

The timing analyzer of the tool provides accurate static timing information for all timing paths in the current design, allowing the tool to optimize the design and improve the slack of critical paths. A delay model allows the calculation of all delays, including propagation and interconnect delays (net transit time).

The timing analyzer computes each gate and interconnect delay, then traces critical paths, calculating minimum and maximum arrival times to points of interest. The timing analyzer uses the critical path values to evaluate design constraints and create timing reports.

The calculation of delays is described in detail in the following sections:

- Path-Based Timing Optimization
- Reporting Retain Arcs
- Reporting Arc Delay Calculations
- Delay Models

# **Path-Based Timing Optimization**

The timing analyzer calculates minimum and maximum path delay costs during optimization and allows the tool to make optimization decisions that improve delay cost. The timing analyzer provides fast timing updates as the design is changed during optimization and has advanced features to support the following:

- Multiphase and multifrequency clocking
- · Automatic time borrowing for latch-based designs
- User-specified multicycle paths and false paths
- Specific point-to-point path delay requirements

You define port signal timing and clock waveforms, and the timing analyzer determines the required maximum and minimum path delays for each timing path in the design. These requirements are compared with the actual path delay to determine slack, which is the difference between the actual and required arrival times. You can display design timing analysis results with the report\_timing command.

The timing analyzer represents a netlist as a directed graph in which nodes in the graph correspond to the pins in the logic network. Edges between nodes (timing arcs) represent two types of connections:

- Net delay—interconnect delay between a driver pin and a load pin its fanout
- Cell delay—timing delay between an input pin and an output pin of a cell

Delay analysis is the calculation of each timing arc's value, which is either a cell delay or a net delay. Rise and fall delay values for a timing path are calculated by addition of the timing arc values. as follows:

#### positive unate timing arc

Combines rise delays with rise delays and fall delays with fall delays. Examples are an AND gate cell delay and an interconnect (net) delay.

### negative unate timing arc

Combines incoming rise delays with local fall delays and incoming fall delays with local rise delays. An example is a NAND gate.

#### non-unate timing arc

Combines local delay with the worst-case incoming delay value. Non-unate timing arcs are present in logic functions whose output value change cannot be predicted by the direction of the change on the input value. An example is an XOR gate.

Because the delay attributes are associated with a timing arc and not with a single pin, both minimum and maximum paths between two pins can be modeled.

#### Note:

The timing analyzer does not store delay equation parameters in terms of specific units. The only restriction the timing analyzer places on the values used is that the units must form an internally consistent system. The recommended units are nanoseconds (delay), picofarads (load), and kilohms (resistance).

Figure A-1 shows how a logic network is converted to a timing graph.

Figure A-1 Converting a Logic Network to a Timing Graph



The timing arcs in flip-flops are from the clock input (clk) to the data output (Q). No direct timing arcs exist from a flip-flop's D input to its Q output.

# **Reporting Retain Arcs**

The tool can load retain arcs for timing models from library files, annotate the retain arcs from SDF input files, and report on these arcs.

Retain arcs are similar to hold-check arcs and are typically used for modeling random access memory (RAM). They are defined between a clock pin and a data output of a RAM, and they are always defined in parallel with the parent arc, which is the ordinary or default

delay arc between the same two pins. A retain arc does not generate an actual timing check during timing analysis. It is simply treated as another delay arc that is connected in parallel with its parent arc.

Clock-to-output retain arcs guarantee that the RAM output does not change for a specific interval of time after the clock edge. When the retain arc delay is less than its parent arc, the retain arc appears in a timing report for only the minimum-delay paths. When the retain arc delay is longer than its parent arc, the retain arc can also appear in the maximum-delay path report with no error messages or warnings.

To report all of the timing arcs for cells in a technology library, including retain arcs, use the -timing\_arcs option with the report\_lib command. Use the check\_timing -retain command to check if the retain arc has a delay greater than its parent arc.

The read\_sdf command supports retain arcs but the write\_sdf command does not.

# **Reporting Arc Delay Calculations**

The report\_delay\_calculation command reports the details of a timing arc delay calculation. The details include cell arcs (from an input pin to an output pin) as well as net arcs (from a source pin to a load pin).

#### The syntax is

```
report_delay_calculation
  -from from_pin -to to_pin
[-min |-max]
[-crosstalk]
[-from_rise_transition value]
[-from_fall_transition value]
[-nosplit]
```

If a cell timing arc exists between the given pins, the details of the cell arc delay calculation are provided. If the given pins are part of the same net, the details of the net arc delay calculation are provided.

The following conditions constitute an error (no delay information is reported):

- The technology library was not loaded in source format with the read lib command.
- No cell or net delay arc exists between the given pins.
- An undefined pin is specified.
- The pins are associated with a nonleaf cell.

- More than one pin is defined with the -from or -to option.
- The arc between the defined pins is not supported.

The format of the output varies on the basis of the delay model type and the interconnect delay tree type (for net delay arcs). If delay values have been back-annotated for the defined arc, the annotated delay is given instead of the calculated delay.

#### **Example**

This example shows a sample output for a cell arc and a net arc. The library is generic cmos, and the tree type is balanced case tree.

```
From pin: U28/A
To pin: U28/Z
arc type :
                         cell
arc sense :
                          unate
Input net transition times: Dt_rise = 0.1458, Dt_fall = 0.0653
Rise Delay computation:
rise_intrinsic 0.48 + rise_slope * Dt_rise 0 * 0.1458 +
rise_resistance * (pin_cap + wire_cap) / driver_count 0.1443 * (2 + 0) / 1
rise_transition_delay: 0.2886
-----
                          0.7686
Total
Fall Delay computation:
fall_resistance * (pin_cap + wire_cap) / driver_count
0.0523 * (2 + 0) / 1
fall_transition_delay: 0.1046
_____
Total
                          0.8746
Net arc output
   From pin:
                    U28/Z
   To Pin:
                    U29/A
   arc type: net
   Wire Loading Model Mode: top
```

# **Debugging Delay Calculations Along a Critical Path**

A typical use of the report\_delay\_calculation command is to assist in debugging the delay calculations along a critical path.

To locate the critical path, use report\_timing -path full -input\_pins. You get a listing similar to the following example.

| Point                | Incr | Path   |
|----------------------|------|--------|
|                      |      |        |
| input external delay | 0.00 | 0.00 f |
| i2 (in)              | 0.00 | 0.00 f |
| cell1/i2 (lower1)    | 0.00 | 0.00 f |
| cell1/C/B (AN2)      | 0.00 | 0.00 f |
| cell1/C/Z (AN2)      | 0.82 | 0.82 f |
| cell1/o1 (lower1)    | 0.00 | 0.82 f |
| cell2/i1 (lower2)    | 0.00 | 0.82 f |
| cell2/C/A (IV)       | 0.00 | 0.82 f |
| cell2/C/Z (IV)       | 0.38 | 1.20 r |
| cell2/o1 (lower2)    | 0.00 | 1.20 r |
| ol (out)             | 0.00 | 1.20 r |
| data arrival time    |      | 1.20   |

The <code>-input\_pins</code> option causes the input pins to be listed in the path in addition to the output pins, thereby providing information on net delays as well as cell delays.

# **Reporting Details of a Cell Delay Arc**

Here are some examples of how to print details of a cell delay and net delay arcs.

- To print details of a cell delay arc, use the report\_delay\_calculation command by defining the input and output pin of a leaf cell along the path. For example, enter prompt> report\_delay\_calculation -from cell1/C/B -to cell1/C/Z
- To print the details of a net delay arc, give the command a driver and a load pin on the same net along the path (the pins must be associated with leaf cells). For example, enter

```
prompt> report_delay_calculation -from cel11/C/Z -to cel12/C/A
```

This example is valid because both cells are leaf cells.

• The following command is not valid because there is no net delay arc associated with from pin (it is not on a leaf cell):

```
prompt> report delay calculation -from cell2/i1 -to cell2/C/A
```

The operating conditions and wire load are taken into account when generating the report data but timing ranges are not because timing ranges typically apply to an entire path (as opposed to a single timing arc).

# **Delay Models**

The timing analyzer uses the timing parameters and the environment attributes described in a technology library to calculate timing delays for designs.

The types of delay analysis are

- Linear (generic cmos)
- CMOS2 (cmos2)
- Nonlinear (table lookup)

Note:

The capacitance of all pins on an interconnected wire contributes to the delay. In this section, references to pins or sums over pins include all pins, both driver and input, unless stated otherwise. In many libraries, however, the delay contribution due to the capacitance of an output pin is assigned to other delays and the capacitance is set to zero. For example in Figure A-3 on page A-13, the calculation uses capacitance values for the three input pins and none for the output pin. This produces the correct result when the library includes a capacitance of zero for the output pin.

# **Linear Delay Model**

The linear delay equation for computing gate delay values is the sum of four terms:

slope delay (D<sub>S</sub>)

The delay incurred from an input pin to an output pin because of a slow logic transition at the input pin.

intrinsic delay (D<sub>I</sub>)

The built-in delay from an input pin to an output pin.

### transition time $(D_T)$

The time a state change takes to complete on a net. This can be constrained as a design rule (max\_transition) and can also be used as a parameter in delay calculations for cells in the fanout of the net.

### connect delay (D<sub>C</sub>)

The time-of-flight delay—the time a logic transition takes to propagate through an interconnect network.

Figure A-2 shows a diagram of the four terms in the delay equation.

Figure A-2 Delay Equation Terms and Timing Arcs (Linear)



The timing analyzer does not store delay equation parameters in terms of specific units. The only restriction the timing analyzer places on the values used is that the units must form an internally consistent system. Synopsys engineers suggest a system of nanoseconds (delay), picofarads (load), and kilohms (resistance).

#### **Example**

This example shows the rise and fall delay equations.

$$D_{rise} = D_{slope-rise} + D_{intrinsic-rise} + D_{transition-rise} + D_{connect-rise}$$

$$D_{fall} = D_{slope-fall} + D_{intrinsic-fall} + D_{transition-fall} + D_{connect-fall}$$

The parameters of these equations are

```
^{D}slope-rise = ^{D}Tprevious_stage \times ^{S}rise ^{D}slope-fall = ^{D}Tprevious_stage \times ^{S}fall
```

The  $D_{Tprevious\_stage}$  value is determined by the arc type.

#### For rise:

arc\_typeD<sub>Tprevious\_stage</sub> positive unaterise negative unatefall nonunatemax(rise,fall)

#### For fall:

arc\_typeD<sub>Tprevious\_stage</sub> positive unatefall negative unaterise nonunatemax(rise,fall)

 $S_{rise}$  = input rise slope sensitivity

 $S_{fall}$  = input fall slope sensitivity

D<sub>intrinsic-rise</sub> = Intrinsic rise delay from library

D<sub>intrinsic-fall</sub> = Intrinsic fall delay from library

### For non-piecewise:

```
\begin{array}{c} D_{\text{transition-rise}} = R_{\text{rise}} \; (C_{\text{pins}} \; + \; C_{\text{wire}}) \, / \, (\text{number of non-three-state} \\ \text{drivers}) \\ D_{\text{transition-fall}} = R_{\text{fall}} \, (C_{\text{pins}} \; + \; C_{\text{wire}}) \, / \, (\text{number of non-three-state} \\ \text{drivers}) \end{array}
```

#### For piecewise:

```
\begin{array}{l} D_{connect-rise} = D_{connect-fall} = \{ \\ & \text{if tree type is best case: 0.0} \\ & \text{if tree type is worst case: } R_{wire} \; (C_{wire} + C_{pinsvp22}) \\ & \text{if tree type is balanced: } R_{wire}/N \; (C_{wire}/N + C_{pin}) \, \} \end{array}
```

 $R_{wire}$  = wire resistance

c<sub>pins</sub> = sum of all pin capacitances on net

C<sub>pin</sub> = individual pin capacitance value

N = number of pins being driven

D<sub>T-rise\_previous\_stage</sub> = transition rise delay at previous stage

D<sub>T-fall\_previous\_stage</sub> = transition fall delay at previous stage

# Slope Delay (D<sub>S</sub>)

The slope delay of an element, D<sub>S</sub>, represents the gate delay resulting from the ramp time of the input signal. A slower input transition results in more slope delay.

```
Ds = D_{Tprevious} \times S
```

### **D**<sub>Tprevious</sub>

The transition time of the previous gate (see "Transition Time  $(D_T)$ " on page A-11). The appropriate transition direction is selected based on the unateness of the timing arc being evaluated.

S

The slope delay factor for the specified timing arc (slope sensitivity).

# Intrinsic Delay (D<sub>I</sub>)

The intrinsic delay of an element, D<sub>I</sub>, is the portion of the total delay that is independent of the element's usage. This is the fixed (or zero-load) delay of an element.

The total intrinsic delay is calculated by scaling these constant values by their corresponding k-factors (see "Environmental Scaling" on page A-28).

# Transition Time (D<sub>T</sub>)

Transition time is the delay the capacitive load on a gate's output pin introduces. It represents the time it takes the output to switch from one logical state to another. The transition time is computed in one of two ways, depending on the technology library:

Linear transition time

$$D_T = R_{drive} \times \left( \sum_{pins} C_{pin} + C_{wire} \right)$$

Piecewise linear transition time

$$D_T = R_{drivei} \times \left( \sum_{pins} C_{pin} + C_{wire} \right) + Y_{adji}$$

In the piecewise linear model, the resistance value ( $R_{drivei}$ ) and a constant term ( $Y_{adji}$ ) can vary with different loading conditions. The piece\_type statement in the technology library determines how the appropriate resistance and constant are selected. The selection is done on the basis of one of the following criteria:

- Total net length
- Total output capacitance
- Output pin capacitance
- Output wire capacitance

A piece\_define statement in the library determines the correlation between resistance and constant term values and the piece\_type. In the case of parallel drivers, the arc transition time is divided by the number of non-three-state drivers.

The total transition time is calculated by scaling the constant values by their corresponding k-factors (see "Environmental Scaling" on page A-28).

# Connect Delay (D<sub>C</sub>)

The connect delay,  $D_C$ , is the time it takes the voltage at an input pin to change after the transition of the driving output pin. Connect delay is also called the time-of-flight delay (the time it takes for a waveform to travel along a wire). The way this delay is calculated is important in the analysis of interconnect network delay. The timing analyzer supports three cases for an estimated interconnect topology (tree type).

Best case (best\_case\_tree) models the case where the load pin is physically adjacent
to the driver. All wire capacitance is incurred, but none of the wire resistance must be
overcome. The best-case connect delay is calculated from the following equation.
Because Rwire is always 0 in this case, the resulting D<sub>C</sub> is always 0.

$$D_{C_{\text{best}}} = R_{\text{wire}}(C_{\text{wire}} + C_{\text{pin}}) = 0$$

 Balanced case (balanced\_tree) models the case where all load pins are on separate, equal branches of the interconnect wire. Each load pin incurs an equal portion of the wire capacitance and wire resistance.

$$D_{C_{\text{balanced}}} = \frac{R_{\text{wire}}}{N} \left( \frac{C_{\text{wire}}}{N} + C_{\text{pin}} \right)$$

Worst case (worst\_case\_tree) models the case where the load pin is at the extreme
end of the wire. Each load pin incurs both the full wire capacitance and the full wire
resistance.

$$D_{C_{worst}} = R_{wire} \left( C_{wire} + \sum_{pins} C_{pin} \right)$$

The three previous equations are used for calculating both the rise and fall delays. The components of these equations are described below. Where applicable, use the rise parameter for calculating the rise delay and the fall parameter for calculating the fall delay.

### R<sub>wire</sub>

Estimated wire resistance on the net determined by the wire load model. Wire length is computed with a global estimation function whose parameter is the number of fanout pins on the net being estimated.

### $C_{\text{wire}}$

The estimated wire capacitance for the net attached to the head of the timing arc for which the delay value is being computed. Wire length is computed with the actual number of fanout pins on the net being estimated and the fanout\_length specifications in the wire\_load group. The estimated value is scaled by the capacitance factor.

 $C_{pin}$ 

Capacitance values for the load pin.

Total connect delay is calculated by scaling the constant values by their corresponding k-factors (see "Environmental Scaling" on page A-28).

# **Delay Calculation (Linear) Example**

Figure A-3 shows the rise delay values for an inverter.

Figure A-3 Delay Values for an Inverter



The inverter input pin is driven by a falling signal with a transition time ( $D_T$ ) of 1.2 ns. The inverter fans out to three NAND gates, each with an input pin capacitance of 1.1. The inverter has an intrinsic rise delay of 1.4, a rise slope sensitivity of 0.02, and an output rise resistance of 0.14. Assuming a best-case RC-interconnect tree type and an estimated interconnect wire capacitance of 2.6, the rise delay is 2.25.

The following is the rise delay calculation for the inverter shown in Figure A-3:

```
\begin{array}{l} D_{intrinsic-rise} = 1.4 \\ S_{rise} = 0.02 \\ R_{rise} = 0.14 \\ \\ C_{pins} = 3 * (1.1) = 3.3 \\ \\ C_{wire} = 2.6 \\ \\ D_{T-fall\_previous\_stage} = 1.2 \\ \\ D_{connect-rise} = 0.0 \text{ for a best case RC-tree} \end{array}
```

```
D_{rise} = Intrinsic + Slope + Transition + Connect
= 1.4 + (1.2 * 0.02) + (0.14)(3.3 + 2.6) + 0.0
= 1.4 + 0.02 + 0.826 + 0.0
= 2.25
```

# **CMOS2 Delay Model**

The CMOS2 delay model is similar to the linear delay model except that it uses delay due to edge rate instead of slope delay. The CMOS2 delay equation for computing gate delay values is the sum of four terms:

intrinsic delay (D<sub>I</sub>)

The built-in delay from an input pin to an output pin.

delay due to input edge rate (D<sub>F</sub>)

The delay incurred at an input pin due to edge rate. At each input pin, the timing analyzer computes the actual edge rate. The edge rate can be different for different pins on the net. Also, the cell delay can have a two-piece dependency on input edge rate. See Figure A-4 for an example of an input rise dependency.

transition delay (D<sub>T</sub>)

The time it takes to change logic value due to loading at an output pin (output resistance times load).

connect delay (D<sub>C</sub>)

The time-of-flight delay—the time it takes a logic transition to propagate through an interconnect network.



Figure A-4 Rise Dependency on Edge Rate (CMOS2)

Figure A-5 shows a diagram of the four terms in the delay equation.

Figure A-5 Delay Equation Terms and Timing Arcs (CMOS2)



The timing analyzer does not store delay equation parameters in terms of specific units. The only restriction the timing analyzer places on the values used is that the units must form an internally consistent system. Synopsys engineers suggest a system of nanoseconds (delay), picofarads (load), and kilohms (resistance).

### **Example**

This example shows the rise and fall delay equations.

For positive unate arcs:

```
D_{rise} = D_{edge-rise} + D_{intrinsic-rise} + D_{transition-rise}
D_{fall} = D_{edge-fall} + D_{intrinsic-fall} + D_{transition-fall}
```

• For negative unate arcs:

```
D_{rise} = D_{edge-fall} + D_{intrinsic-rise} + D_{transition-rise}
D_{fall} = D_{edge-rise} + D_{intrinsic-fall} + D_{transition-fall}
```

For non-unate arcs:

```
D_{rise} = D_{edge-max} + D_{intrinsic-rise} + D_{transition-rise}
D_{fall} = D_{edge-max} + D_{intrinsic-fall} + D_{transition-fall}
```

### **Equation Parameters**

The parameters of these equations are

```
D_{edge-rise} = edge\_rate\_sensitivity\_r0 x
         min(edge_rate_breakpoint_r1 - edge_rate_breakpoint_r0,
         edge_rate_rise_delay - edge_rate_breakpoint_r0) +
         edge_rate_sensitivity_r1 x max(0, edge_rate_rise -
         edge_rate_breakpoint_r1)
D_{edge-fall} = edge\_rate\_sensitivity\_f0 x
         min(edge_rate_breakpoint_f1 - edge_rate_breakpoint_f0,
         edge_rate_fall_delay - edge_rate_breakpoint_f0) +
edge_rate_sensitivity_f1 x max(0, edge_rate_fall -
         edge_rate_breakpoint_f1)
edge_rate_sensitivity_r0 = (arc) rising edge-rate sensitivity of first piece
edge_rate_sensitivity_r1 = (arc) rising edge-rate sensitivity of second piece
edge_rate_breakpoint_r0 = (input pin) first breakpoint on rising edge-rate
               sense curve
edge_rate_breakpoint_r1 = (input pin) second breakpoint
         on rising edge-rate sense curve
edge_rate_rise_delay = edge_rate_rise +
         edge_rate_load_rise x (interconnect and input pin
         capacitance - reference capacitance of the output pin
         driving the net + (estimated connect delay/rise
         resistance of driving cell))
edge_rate_rise = the zero-load rise edge rate for a
         driver pin
edge_rate_sensitivity_f0 = (arc) falling edge-rate
         sensitivity of first piece
edge_rate_sensitivity_f1 = (arc) falling edge-rate
         sensitivity of second piece
edge_rate_breakpoint_f0 = (input pin) first breakpoint on
         falling edge-rate sense curve
edge_rate_breakpoint_f1 = (input pin) second breakpoint
         on falling edge-rate sense curve
edge_rate_fall_delay = edge_rate_fall +
         edge_rate_load_fall x (input net capacitance -
```

```
reference capacitance + (estimated connect delay/fall
           resistance of driving cell))
edge_rate_fall = the zero-load fall edge rate for a
           driver pin
edge_rate_load_fall = the load dependent falling edge
           rate capability for a driver pin.
edge_rate_load_rise = the load dependent rising edge
          rate capability for a driver pin.
Dintrinsic-rise = Intrinsic rise delay from library
Dintrinsic-fall = Intrinsic fall delay from library
For non-piecewise:
D_{transition-rise} = R_{rise} \times (C_{pins} + C_{wire})
D_{transition-fall} = R_{fall} \times (C_{pins} + C_{wire})
For piecewise:
D_{transition-rise} = R_{drivei-rise} \times (C_{pins} + C_{wire}) + Y_{adji}
D_{transition-fall} = R_{drivei-fall} \times (C_{pins} + C_{wire}) + Y_{adji}
D<sub>connect-rise</sub> = { if tree type is best case:
                  if tree type is worst case: (R_{wire} (C_{wire} + C_{pins}) \times K_{rc\_rise})
                  if tree type is balanced:
                                                     (R<sub>wire</sub>/N (C<sub>wire</sub>/N + C<sub>pin</sub>) x K<sub>rc_rise</sub>) }
D<sub>connect-fall</sub> = { if tree type is best case:
                                                     0.0
                  if tree type is worst case: (Rwire (Cwire + Cpins) x K_{rc\ fall})
                  if tree type is balanced: (R_{wire}/N (C_{wire}/N + C_{pin}) \times K_{rc\_fall}) }
R_{wire} = Wire resistance
C_{pins} = Sum of all pin capacitances on net
C_{pin} = Individual pin capacitance value
N = Number of pins being driven
K_{rc rise} = Library multiplication factor
```

# Edge Rate Delay (D<sub>F</sub>)

The delay due to the input edge rate of an element, D<sub>E</sub>, represents the delay incurred at an input pin due to edge rate.

# Intrinsic Delay (D<sub>I</sub>)

The intrinsic delay of an element,  $D_l$ , is the portion of the total delay that is independent of the element's use. This is the fixed (or zero-load) delay of an element.

Total intrinsic delay is calculated by scaling these constant values by their corresponding k-factors (see "Environmental Scaling" on page A-28).

# Transition Time (D<sub>T</sub>)

Transition time is the delay introduced by the capacitive load on a gate's output pin. It represents the time it takes the output to switch from one logical state to another. Transition time is computed in one of two ways, depending on the technology library:

Equation A-1 Linear transition time

$$D_T = R_{drive} \times \left( \sum_{pins} C_{pin} + C_{wire} \right)$$

Equation A-2 Piecewise linear transition time

$$D_T = R_{drivei} \times \left( \sum_{pins} C_{pin} + C_{wire} \right) + Y_{adji}$$

In the piecewise linear model, the resistance value ( $R_{drivei}$ ) and a constant term ( $Y_{adji}$ ) can vary with different loading conditions. The piece\_type statement in the technology library determines how the appropriate resistance and constant are selected. The selection is done on the basis of one of the following criteria:

- Total net length
- Total output capacitance
- · Output pin capacitance
- Output wire capacitance

A piece\_define statement in the library determines the correlation between resistance and constant term values and the piece\_type.

Total transition time is calculated by scaling the constant values by their corresponding k-factors (see "Environmental Scaling" on page A-28).

# Connect Delay (D<sub>C</sub>)

Connect delay,  $D_C$ , is the time it takes the voltage at an input pin to change after the transition of the driving output pin. Connect delay is also called the time-of-flight delay (the time it takes for a waveform to travel along a wire). The way this delay is calculated is important in the analysis of interconnect network delay. The timing analyzer supports three cases for an estimated interconnect topology (tree type).

Best case (best\_case\_tree) models the case where the load pin is physically adjacent
to the driver. All wire capacitance is incurred, but none of the wire resistance must be
overcome. The best-case connect delay is calculated from the following equation.
Because Rwire is always 0 in this case, the resulting D<sub>C</sub> is always zero.

$$D_{C_{best}} = R_{wire}(C_{wire} + C_{pin}) = 0$$

• Balanced case (balanced\_tree) models the case where all load pins are on separate, equal branches of the interconnect wire. Each load pin incurs an equal portion of the wire capacitance and wire resistance.

$$D_{C_{\text{balanced}}} = \frac{R_{\text{wire}}}{N} \left( \frac{C_{\text{wire}}}{N} + C_{\text{pin}} \right)$$

Worst case (worst\_case\_tree) models are different for the CMOS2 model than they are
for other models (the resistance is divided by the fanout N). The load pin is at the extreme
end of the wire. Each load pin incurs both the full wire capacitance and a portion of the
wire resistance.

$$D_{C_{worst}} = \frac{R_{wire}}{N} \left( C_{wire} + \sum_{pins} C_{pin} \right)$$

These equations are used for calculating both the rise and fall delays. Where applicable, use the rise\_parameter for calculating the rise delay and the fall\_parameter for calculating the fall delay. Descriptions of the components in the equation follow.

#### Rwire

Estimated wire resistance on the net determined by the wire load model. Wire length is computed with a global estimation function whose parameter is the number of fanout pins on the net being estimated. The estimated value is scaled by the resistance factor.

#### Cwire

Estimated wire capacitance for the net attached to the head of the timing arc for which the delay value is being computed. Wire length is computed with the actual number of fanout pins on the net being estimated and the fanout\_length specifications in the wire\_load group. The estimated value is scaled by the capacitance factor.

#### $C_{pin}$

Capacitance values for the load pin.

Total connect delay is calculated by scaling the constant values by their corresponding k-factors (see "Environmental Scaling" on page A-28).

## **Delay Calculation (CMOS2) Example**

This example shows the cell delay across a NAND2 gate from pin B to pin X.

```
wire_load_model: MEDIUM
tree_type: balanced_case
operating conditions: nominal
port edge rate: 0.0
```



The previous driver, an INVERTER gate, has the following characteristics:

```
cell(INVERTER) {
   area : 1;
   pin(X) {
     function : "A'";
     direction : output;
   edge_rate_rise : 0.12;
   edge_rate_fall : 0.13;
   edge_rate_load_rise : 4.5;
   edge_rate_load_fall : 2.5;
   timing() {
   edge_rate_sensitivity_r0 : 0.20;
   edge_rate_sensitivity_f0 : 0.10;
   edge_rate_sensitivity_r1 : 0.15;
   edge_rate_sensitivity_f1 : 0.05;
   intrinsic_rise : 0.10;
```

```
intrinsic_fall : 0.12;
  rise_resistance : 2.0;
  fall_resistance : 1.0;
  related_pin : "A";
  }
  pin(A) {
    direction : input;
    capacitance : 0.10;
  }
}
```

#### **NAND2 Gate Library Description**

```
cell(NAND2) {
 area : 1;
 pin(X) {
    function : "(A B)'";
   direction : output;
    edge_rate_rise : 0.24;
    edge_rate_fall : 0.14;
    edge_rate_load_rise : 5.4;
    edge_rate_load_fall : 3.4;
    timing() {
    intrinsic_rise : 0.34;
    intrinsic_fall : 0.24;
    rise_resistance : 3.4;
    fall_resistance : 1.4;
    edge rate sensitivity r0 : 0.24;
    edge rate sensitivity f0: 0.14;
    edge_rate_sensitivity_r1 : 0.14;
    edge_rate_sensitivity_f1 : 0.04;
    related_pin : "A";
    timing() {
    intrinsic_rise : 0.34;
    intrinsic_fall : 0.24;
    rise_resistance : 3.4;
    fall_resistance : 1.4;
    edge_rate_sensitivity_r0 : 0.24;
    edge rate sensitivity f0 : 0.14;
    edge rate sensitivity r1: 0.14;
    edge_rate_sensitivity_f1 : 0.04;
    related_pin : "B";
 pin(A) {
   direction : input;
    capacitance : 0.10;
  }
```

```
pin(B) {
   direction : input;
   capacitance : 0.10;
}
```

#### **Library Global Values**

The library global values are

```
delay model : cmos2;
time_unit : "1ns";
default_max_transition : 12.00;
default_edge_rate_breakpoint_r0 : 0.500;
default_edge_rate_breakpoint_r1 : 3.000;
default edge rate breakpoint f0 : 0.500;
default edge rate breakpoint f1: 3.000;
default reference capacitance: 0.000;
default setup coefficient : 1.0;
default_hold_coefficient : 1.0;
default_rc_rise_coefficient : 1.0;
default rc fall coefficient : 1.0;
wire load("MEDIUM") {
  resistance : 0.00003;
  capacitance : 0.0001;
 area : 0;
 fanout length(1,800);
  fanout length(6,2800);
  fanout_length(7,3200.0);
  fanout_length(14,6000.0);
  fanout_length(15,6500.0);
  slope : 400;
```

For this example, a balanced-case tree type is used with the MEDIUM wire load model, and nominal operating conditions are assumed. Net N1 connects the driver, an INVERTER pin X, to the NAND2 pin B.

This net has the following characteristics:

```
pin_capacitance: 0.1
wire_capacitance: 0.08
total_capacitance: 0.18
wire_resistance: 0.024
```

Consider the rising cell delay across the NAND2 (B to X). The rising delay on NAND2 pin X requires a fall transition on the input B.

```
rise_cell_delay = D<sub>e(input falling)</sub> + D<sub>i_rise</sub> + D<sub>t_rise</sub>
```

To determine the rise cell delay:

```
drive pin = u1/X (INVERTER)
```

The effective capacitance noted by the previous driver is used to calculate the actual falling edge rate at B (ERFD). The fall resistance is from the previous driver, the INVERTER cell.

The delay due to input edge rate is a two-segment, piecewise linear dependence on ERFD. The breakpoints are found in the library. Calculating the delay due to edge rate (De\_fall) is as follows:

The intrinsic rise of the NAND2 is from the library.

```
Di_rise = rise_intrinsic
Di rise = 0.34
```

The timing analyzer computes the NAND2 transition time, using the rise\_resistance of this cell and the capacitance at net O1, which the NAND2 drives.

```
Dt_rise = rise_resistance * net_cap
Dt_rise = 3.4 * 3.08
Dt_rise = 10.472
```

To compute the total cell delay,

```
rise_cell_delay = De + Di_rise + Dt_rise
rise_cell_delay = 0.012712 + 0.34 + 10.472
rise_cell_delay = 10.8247
```

The following is the full timing report:

```
Design Wire Loading Model Library
-----
TWO_INV MEDIUM cmos2_c
Startpoint: I1 (input port)
Endpoint: O1 (output port)
```

Path Group: (none)
Path Type: max

Point Incr Path

input external delay 0.00 0.00 r
I1 (in) 0.00 0.00 r
u1/A (INVERTER) 0.00 0.00 r
u1/X (INVERTER) 0.20 0.20 f
u2/B (NAND2) 0.00 0.21 f
u2/X (NAND2) 10.82 11.03 r
O1 (out) 0.07 11.11 r
data arrival time 11.11

### **Nonlinear Delay Model**

The nonlinear delay model stores vendor-specific delay information in the technology library in the form of lookup tables. This model supports a close correlation between nonlinear vendor delay models and the timing analyzer calculations.

Delay analysis involves calculating total delay, which comprises cell and connect delay.

$$D_{total} = D_{cell} + D_{c}$$

## $\mathsf{D}_{\mathsf{cell}}$

The delay contributed by the gate itself, typically measured from the 50 percent input pin voltage to the 50 percent output pin voltage.

 $D_c$ 

The connect delay. It is either calculated by using the <code>tree\_type</code> attribute in the <code>operating\_conditions</code> group and the selected wire load model, or read in from an SDF file as in the standard delay equation. Connect delay is calculated by the same method used in other delay equations.

The CMOS nonlinear timing model supports two methods of computing  $D_{cell}$ . Although you can mix the two methods in a technology library, you typically specify only the method that best correlates to the characterized library data.

The timing analyzer can compute  $D_{cell}$  directly by performing table lookup and interpolation in a cell delay table provided in the library or it can compute  $D_{cell}$  by using the propagation and transition tables:

$$D_{cell} = D_{propagation} + D_{transition}$$

#### D<sub>propagation</sub>

A typical measurement for  $D_{propagation}$  is the time from the 50 percent input pin voltage until the gate output just begins to switch, for example the 10 percent output voltage. Thus, when a  $D_{transition}$  value defined from the 10 percent to 50 percent output voltage is added to  $D_{propagation}$ , the result is a 50 percent input to 50 percent output cell delay.

#### D<sub>transition</sub>

The time required for the output pin to change state. This is sometimes referred to as the output ramp time.

 $D_{transition}$  is the time between two reference voltage levels on the output pin. These levels can be 20 percent to 80 percent or 10 percent to 50 percent, for example.  $D_{transition}$  is computed by performing table lookup and interpolation.

If cell delay tables are provided for a timing arc, the total delay equation used is

$$D_{total} = D_{cell} + D_{c}$$

If propagation delay tables are provided instead, the total delay equation becomes

$$D_{total} = D_{propagation} + D_{transition} + D_{c}$$

When transition tables in the library are indexed by input pin transition, the transition or slew of a gate's input pin affects the transition of an output pin. As cells are being swapped and evaluated during optimization, this input or output transition effect can cause delay changes to ripple outside of the cells local to the change. Early in the design flow, you might not need to account for this ripple effect.

# **Library Cell Timing Arcs**

The following tables are defined for each library cell delay timing arc:

- · Rise propagation
- Cell rise
- Fall propagation
- Cell fall
- · Rise transition
- Fall transition

#### Note:

Every delay arc can have propagation tables or cell tables, but not both. Also, every delay arc must have transition tables.

Each delay table is indexed by one through three of the following six variables:

- input\_net\_transition
- output\_net\_length
- total output net capacitance
- related out total output net capacitance
- output net pin cap
- output net wire cap

The values stored in the table are the propagation or transition time value. Interpolation is used to determine values between points. Breakpoints in the table can be arbitrarily defined. Each table maintains its own breakpoints, independent of other tables. Tables of different dimensions, breakpoints, and index variables can be intermixed within one technology library.

The following tables are defined for each library-cell-constraint timing arc, as with setup and hold:

- rise constraint
- fall\_constraint

Each constraint table can be indexed by one through three of the following two variables:

- Constrained pin transition time
- Related pin transition time

This time the values stored in the table are the constraint values. The constraint tables allow setup and hold values to vary depending on the transition at the D-pin (constrained pin) and the clock pin (related pin) of a latch.

Because much of the information stored in a table is common to other tables, table templates and inheritance are supported. See the Library Compiler documentation for more details.

To use the nonlinear delay model, activate a technology library that specifies the nonlinear delay model.

# **Delay Calculation Example**

Figure A-6 illustrates the process for determining the fall delay across a timing arc of cell U1.

Figure A-6 Nonlinear Delay Calculation Example



Examine the fall propagation table: a two-dimensional table indexed by total output capacitance and input transition time. The total output capacitance is the sum of pin and wire capacitance on net n1 ( $C_{total}$  in Figure A-6). Input transition time is determined by evaluation of the transition time at the previous gate U0. Because the arc under evaluation in U1 is negative unate, the rise transition table at U0 is evaluated to determine the U1 input transition time. Assume that  $C_{total}$  is 110.1 and the input transition time is 0.34. Use these two values to index into the U1 fall propagation table.

Figure A-7 shows two-dimensional interpolation.

Figure A-7 Two-Dimensional Interpolation



In Figure A-7, the black dots represent points defined in the table. The four points with heights shown in the Z-axis are the neighboring points chosen for interpolation. The shaded area is the surface used for interpolation.

The fall transition time is computed by evaluation of the fall transition table. In this case, the table is a one-dimensional table based on total output capacitance. The output capacitance value (110.1) was calculated previously. Through simple linear interpolation within the table, the fall transition time is determined.

The fall propagation delay is then added to the fall transition time to compute the cell delay for a falling transition across the given timing arc of cell U1.

If a cell delay table is defined in the technology library for U1 instead of a propagation table, the table evaluations occur in the same way, but the transition result is not included when calculating the cell delay for U1.

## **Environmental Scaling**

When calculating total delay, the timing analyzer individually scales each scalable parameter of  $D_{total}$ . Each scalable component of the total delay has its own global parameters to model the effects of variation in process, temperature, and voltage on the nominal case.

The following scaling factor is applied to individual components of the delay equation:

$$(1 + \Delta_{\nabla}K_{\nabla})$$
  $(1 + \Delta_{\nabla}K_{\nabla})$   $(1 + \Delta_{\nabla}K_{\nabla})$ 

 $\Delta_{V}$  = Change in voltage from library-specified nominal value.

 $K_V$  = Scale factor for change in voltage.

 $\Delta_T$  = Change in temperature from library-specified nominal value.

 $K_T$  = Scale factor for change in temperature.

 $\Delta_{P}$  = Change in process from library-specified nominal value.

 $K_P$  = Scale factor for change in process.

Each component of the delay equation can have different values for  $K_V$ ,  $K_T$ , and  $K_P$ , allowing it to be scaled independently of the other components. See the *Library Compiler Reference Manual, Volumes 1 and 2*, for more details on environmental scaling.

# Index

| A                                             | scan chain disabling 5-19              |
|-----------------------------------------------|----------------------------------------|
| annotated delay, report 6-17                  | CCS timing libraries                   |
| annotation, back 6-1                          | scaling 4-15                           |
| arrival time 1-3                              | cell delay arc, print details A-6      |
| asyncrhonous clocks 2-16                      | cell delay, defined 6-2                |
| attributes, timing path 7-20                  | check_timing command 7-5               |
| auto_link_disable variable 6-25               | clock 1-11, 2-1                        |
| auto_iiiik_disable variable 0-25              | asynchronous 2-12, 2-16                |
| _                                             | clock divider 2-29                     |
| В                                             | creating 2-2                           |
| pack-annotation 6-1                           | exclusive 2-12, 2-16                   |
| parasitics 6-25                               | expanding multiple clocks 2-15         |
| removing 6-19                                 | expansion 2-14<br>generated clock 2-29 |
| reporting 6-18                                | ideal 1-26                             |
| SDF conditional arc cell delay 6-10           | ideal latency 2-6                      |
| pest-case/worst-case operating conditions 4-5 | latency 2-3, 2-5                       |
| porrowing time in latch paths 1-17, 9-3       | multiple clocks 2-12                   |
| oudgeting 1-35                                | mutliclock path delays 3-11            |
| oungeming i de                                | network latency 2-3                    |
|                                               | network report 7-22                    |
| C                                             | propagated 2-40                        |
| capture event 1-3                             | propagated latency 2-5                 |
| case analysis                                 | pulse 2-22                             |
| and mode analysis 5-24                        | reconvergence pessimism removal 4-16   |
| constant propagation log file 5-21            | report 2-12                            |
| removing 5-21                                 | sense 2-18                             |
| reporting 5-20                                | source latency 2-3, 2-7                |

specifying clock network effects 2-3 report\_crpr 4-21 synchronous 2-12, 2-14 report delay calculation 1-25, 7-18, A-4 uncertainty 2-3, 2-8 report\_design 5-38 report disable timing 5-38 clock network non-unate 2-35 report ideal network 5-16 report\_interclock\_relation 2-15 clock planning 1-35 report lib 1-24 clock reconvergence pessimism removal 4-16 report net 5-16, 6-16 merging of points 4-21 report\_port 5-7 reporting 4-21 report timing 7-10 threshold for removal 4-20 report\_timing\_derate 4-15 transparent latch 4-20 route\_opt 1-39 clock tree synthesis 1-37 run signoff 1-40 clock\_opt command 1-37 set mode 5-25 clock-gating check 1-7 set annotated check 6-15 CMOS2 delay model A-14 set annotated delay 6-13 collection, timing path 7-19 set\_case\_analysis 5-19 commands set clock gating check 2-25 check\_timing 7-5 set\_clock\_groups 2-16 clock\_opt 1-37 set\_clock\_latency 2-6, 2-7 create clock 2-2 set clock sense 2-20 create\_generated\_clock 2-29, 2-30, 2-31 set clock transition 2-11 create operating conditions 4-3 set clock uncertainty 2-8 define\_scaling\_lib\_group 4-15 set data check 3-29 enable hier si 1-35 set\_disable\_clock\_gating\_check 2-28 get\_timing\_paths 7-19 set disable timing 3-16, 5-38 group\_path 1-31 set drive 5-7, 5-9 place opt 1-36 set\_driving\_cell 5-7 read parasitics 6-25 set\_false\_path 3-16 read\_sdf 6-3 set\_fix\_hold 1-5 remove annotated delay 6-20 set\_ideal\_network 5-14 remove\_attribute 5-16 set input delay 5-2 remove\_case\_analysis 5-21 set\_input\_transition 5-10 remove\_clock\_groups 2-17 set load 5-11, 6-22 remove\_ideal\_net 5-16 set\_max\_delay 3-17 remove ideal network 5-16 set max time borrow 9-16 remove wire load model 5-31 set min delay 3-17 remove\_wire\_load\_selection\_group 5-32 set min library 4-12 report case analysis 5-20 set\_multicycle\_path 3-18 report\_clock 2-12 set operating conditions 4-4 report\_clock\_timing 7-22 set\_output\_delay 5-5 report\_constraint 7-7 set\_propagated\_clock 2-6, 2-41

| set_resistance 6-24                           | delay analysis A-2                |
|-----------------------------------------------|-----------------------------------|
| set_timing_derate 4-13                        | delay calculation 1-14, A-6       |
| set_wire_load_mode 5-31                       | debug A-6                         |
| set_wire_load_model 1-27, 5-31, 9-24          | on-chip variation 4-11            |
| set_wire_load_selection_group 5-32            | reporting A-4                     |
| write_sdc 1-20                                | delay calculation report 7-18     |
| write_sdf 6-12                                | delay models A-7                  |
| connect delay, defined 6-3                    | CMOS2 A-14                        |
| constant propagation                          | linear delay model A-7            |
| log file 5-21                                 | nonlinear A-24                    |
| constrained pin (for data check) 3-29         | delay profile 8-14                |
| constraint checking (check_timing command)    | delay, negative 4-13              |
| 7-5                                           | derating factors 4-12             |
| constraint report (report_constraint command) | design budgeting 1-35             |
| 7-7                                           | Design Compiler 1-26              |
| constructs, SDF 6-5                           | design partitioning 1-29          |
| create_clock command 2-2                      | glue logic 1-30                   |
| create_generated_clock command 2-29, 2-30,    | register retiming 1-33            |
| 2-31                                          | topographical mode 1-28           |
| create_operating_conditions command 4-3       | wire load models 1-27             |
| critical path 1-8                             | design planning 1-35              |
| crosstalk 1-35                                | design rules 1-40                 |
| CRPR (clock reconvergence pessimism           | cost priority 1-41                |
| removal) 4-16                                 | SDC commands 1-40                 |
|                                               | Design Vision 8-2                 |
| D                                             | disabled timing arc report 5-38   |
| _<br>data checks                              | divide-by clock 2-29              |
| clock domains 3-32                            | drive capability 5-7              |
| nochange check 3-31                           | driving cell 5-6                  |
| set_data_check command 3-29                   | DSPF 6-26                         |
| timing reports 3-31                           |                                   |
| db library data 1-24                          | _                                 |
| define_scaling_lib_group command 4-15         | E                                 |
| delay                                         | enable_hier_si command 1-35       |
| cells 6-2                                     | endpoint of timing path 3-16      |
| load 6-2, 6-9                                 | environmental scaling factor A-28 |
| net 6-3                                       | estimate_io_latency variable 2-38 |
| removing annotated 6-20                       | exclusive clocks 2-16             |
| report on annotated 6-17                      | expanding clocks 2-14             |
| setting net and cell 6-13                     | 5parianing 0.00000 E 1 1          |

| extraction 1-39                                      | 1                                          |
|------------------------------------------------------|--------------------------------------------|
|                                                      | I/O latency                                |
| F                                                    | calculating for input paths 2-39           |
| false paths 3-16                                     | calculating for output paths 2-40          |
| •                                                    | effect of -network_latency_included option |
| feedback loop 5-37                                   | 2-38                                       |
| files                                                | IC Compiler 1-34                           |
| SDF, command to write 6-12                           | clock planning 1-35                        |
| Standard Delay Format (SDF) 6-2                      | clock tree synthesis 1-37                  |
|                                                      | clock_opt command 1-37                     |
| G                                                    | design budgeting 1-35                      |
|                                                      | design planning 1-35                       |
| gated clock<br>checking 2-24                         | extraction 1-39                            |
| _                                                    | placement 1-35                             |
| generated clock 2-29                                 | route_opt command 1-39                     |
| get_timing_paths command 7-19                        | routing 1-38                               |
| glue logic 1-30                                      | SI 1-35                                    |
| graphical user interface (GUI) 8-1                   | sign-off tools 1-40                        |
| delay profile 8-14                                   | ideal clocking 1-26                        |
| Design Vision 8-2                                    | ideal latency 2-6                          |
| gui_start 8-2                                        | ideal networks 5-12                        |
| gui_stop 8-5                                         | creating 5-14                              |
| menu commands 8-5, 8-6                               | latency and transition times 5-17          |
| online help 8-5                                      | propagation of property 5-13               |
| path delay profile 8-14                              | removing 5-16                              |
| path element table 8-13                              | reporting 5-16                             |
| path inspector 8-9                                   | ideal objects                              |
| path schematic 8-12                                  | retrieving 5-17                            |
| path slack histogram 8-7 timing analysis driver 8-16 | input delay 1-12, 5-2                      |
|                                                      | input paths, calculating I/O latency 2-39  |
| group_paths command 1-31                             | input port                                 |
|                                                      | library pin 5-7                            |
| H                                                    | timing requirements 5-2                    |
| hold check 1-4                                       |                                            |
| default delay calculation 3-12                       | L                                          |
| examples 4-8                                         | latch-based designs                        |
| for flip-flops 1-16                                  | constraining 9-11, 9-24                    |
|                                                      | D latch (Verilog) 9-3                      |
|                                                      | D latch (VHDL) 9-2                         |
|                                                      | general structure 9-4                      |

latch transparency 9-2 linear block encoder and decoder 9-17 linear block encoder and decoder (VHDL) 9-20 relative slack balancing 9-5 time borrowing 1-17, 9-3 timing 1-16 two-phase designs 9-12 two-phased clocks 9-25 latency 2-5 clock network report 7-22 ideal 2-6 propagated 2-5 source 2-7 launch event 1-3 lavout clock-related commands 2-42 .lib library data 1-24 Liberty (.lib) library data 1-24 Liberty NCX 1-24 library cell timing arcs A-25 library groups (scaling) 4-15 library timing data 1-24 load delay defined 6-2, 6-9 load values, report 6-16

# M

maximum delay calculation 3-12 maximum-delay parameters 4-7 menu commands in GUI 8-5, 8-6 minimum delay calculation 3-12 minimum-delay parameters 4-7 min-max libraries 4-12 mode analysis 5-23 and case analysis 5-24 mode groups 5-23 reporting 5-26

setting modes on cells 5-25 multiclock path delays 3-11 multicycle paths 3-18 setup and hold calculation 3-21

## Ν

negative delay 4-13 negative unate timing arc A-2 net delay 6-3 net load, annotating 6-22 net parasitics, annotating 6-25 net resistance, annotating 6-24 network latency 2-3 nonlinear delay model A-24 nonsequential constraints 3-28 nonunate timing arc A-2

# 0

on-chip variation clock reconvergence pessimism 4-16 delay calculation 4-11 operating conditions 4-5 operating conditions 4-2 analysis mode summary 4-8 best-case/worst-case mode 4-5 derating factors 4-12 library definition 4-2 on-chip variation delay calculation 4-11 on-chip variation mode 4-5 setting 4-4 single mode 4-5 tree type 4-3 output delay 1-13, 5-5 output paths, calculating I/O latency 2-40 output port library pin 5-7 timing requirements 5-5

| P                                     | propagated latency 2-5                     |
|---------------------------------------|--------------------------------------------|
| parasitics, back-annotation 6-25      | pulse clock 2-22                           |
| partitioning 1-29                     | PVT operating conditions 4-2               |
| path                                  | PVT scaling 4-15                           |
| clock network report 7-29             |                                            |
| timing 3-1                            | D                                          |
| path delay                            | R                                          |
| default 3-9                           | read_parasitics command 6-25               |
| maximum delay calculation 3-12        | read_sdf command 6-3                       |
| maximum/minimum delay calculation     | sdf constructs 6-5                         |
| examples 3-13                         | reconvergent logic 4-17                    |
| minimum delay calculation 3-12        | recovery check 1-7                         |
| multiple clocks 3-11                  | register retiming 1-33                     |
| profile 8-14                          | related pin (for data check) 3-29          |
| path element table 8-13               | removal check 1-7                          |
| path groups 1-9, 3-2                  | remove_annotated_delay command 6-20        |
| path inspector 8-9                    | remove_attribute command 5-16, 9-16        |
| delay profile, path 8-14              | remove_case_analysis command 5-21          |
| path delay profile 8-14               | remove_clock_groups command 2-17           |
| path element table 8-13               | remove_ideal_net command 5-16              |
| path schematic 8-12                   | remove_ideal_network command 5-16          |
| path slack histogram 8-7              | remove_wire_load_model command 5-31        |
| path specification 3-4                | remove_wire_load_selection_group command   |
| efficiency 3-23                       | 5-32                                       |
| order of precedence 3-26              | report_annotated_check command 6-18        |
| path types 1-6                        | report_annotated_delay command 6-17        |
| paths 1-7                             | report_annotated_delay output example 6-17 |
| critical 1-8                          | report_case_analysis command 5-20          |
| delay calculation 1-14                | report_clock command 2-12                  |
| grouping 1-9, 1-31                    | report_clock_timing command 7-22           |
| input delay 1-12<br>output delay 1-13 | options 7-25                               |
| timing exceptions 1-12                | report_constraint command 7-7              |
| place_opt command 1-36                | report_crpr command 4-21                   |
| placement 1-35                        | report_delay_calculation command 1-25,     |
| port                                  | 7-18, A-4                                  |
| capacitance, load 5-11                | report_design command                      |
| library pin 5-7                       | output example 5-38                        |
| PrimeTime 1-40                        | timing disabled cells and pins 5-38        |
| propagated clock 2-40                 | report_disable_timing command 5-38         |

| report_ideal_network command 5-16               | read_sdf examples 6-12                      |
|-------------------------------------------------|---------------------------------------------|
| report_interclock_relation command 2-15         | triplet data 4-7                            |
| report_lib command 1-24                         | SDF conditional arcs                        |
| report_net command 5-16, 6-16                   | back-annotated cell delay 6-10              |
| report_net output example 6-16                  | sense of clock 2-18                         |
| report_port command 5-7                         | set_annotated_check command 6-15            |
| report_timing command 7-10                      | set_annotated_delay command 6-13            |
| clock path (full_clock) 7-16                    | set_case_analysis command 5-19              |
| -from, -to 7-14                                 | set_clock_gating_check command 2-25         |
| min/max 7-17                                    | set_clock_groups command 2-16               |
| net delays (-input_pins) 7-15                   | set_clock_latency command 2-6, 2-7          |
| net names 7-15                                  | set_clock_sense command 2-20                |
| -nworst and -max_paths 7-17                     | set_clock_transition command 2-11           |
| options 7-13                                    | set_clock_uncertainty command 2-8           |
| path details reported 7-14 transition time 7-15 | set_data_check command 3-29                 |
| report_timing_derate command 4-15               | set_disable_clock_gating_check command 2-28 |
| report_wire_load command 5-35                   | set_disable_timing command 3-16, 5-38       |
| reporting commands 7-2                          | set_drive command 5-7, 5-9                  |
| required time 1-3                               | set_driving_cell command 5-7                |
| resistance values                               | set_false_path command 3-16                 |
| report 6-16                                     | order of precedence 3-25                    |
| resistance, annotating 6-24                     | set_fix_hold command 1-5                    |
| retiming registers 1-33                         | set_ideal_network command 5-14              |
| route_opt command 1-39                          | set_input_delay command 5-2                 |
| routing 1-38                                    | set_input_transition command 5-10           |
| RSPF 6-26                                       | set_load command 5-11, 6-22                 |
| RTL load annotation 6-27                        | set_max_delay command 3-17                  |
| run_signoff command 1-40                        | order of precedence 3-25                    |
| S                                               | set_max_time_borrow command 9-16 undo 9-16  |
|                                                 | set_min_delay comand                        |
| scaling library groups 4-15                     | order of precedence 3-25                    |
| scan chain, disabling 5-19                      | set_min_delay command 3-17                  |
| schematic, path 8-12                            | set_min_library command 4-12                |
| SDC (Synopsys Design Constraints) 1-19          | set_mode command 5-25                       |
| SDF constructs 6-4                              | set_multicycle_path command 3-18            |
| constructs used by read_sdf command 6-5         | order of precedence 3-25                    |
| output file versions 6-12                       | set_operating_conditions command 4-4        |

| set_output_delay command 5-5                                       | read 6-3                                                      |
|--------------------------------------------------------------------|---------------------------------------------------------------|
| set_propagated_clock command 2-6, 2-41                             | report 6-18                                                   |
| set_resistance command 6-24                                        | timing analysis driver (GUI) 8-16                             |
| set_timing_derate command 4-13                                     | timing arc                                                    |
| set_wire_load_mode command 5-31                                    | library cell A-25                                             |
| set_wire_load_model command 1-27, 5-31, 9-24                       | negative unate A-2<br>nonunate A-2                            |
| set_wire_load_selection_group command 5-32                         | timing check removing 6-20                                    |
| setup check 1-4                                                    | timing constraint checking 7-5                                |
| default delay calculation 3-12                                     | timing exceptions 1-12                                        |
| examples 4-8                                                       | efficiency 3-23                                               |
| for flip-flops 1-16                                                | false paths 3-16                                              |
| SI 1-35                                                            | multicycle paths 3-18                                         |
| sign-off tools 1-40                                                | order of precedence 3-25                                      |
| single-cycle path delay 3-9                                        | removing 3-27 set_max_delay and set_min_delay 3-17            |
| skew 2-4                                                           | startpoint and endpoint 3-16                                  |
| clock network report 7-23                                          | summary 3-15                                                  |
| interclock reporting 7-25, 7-28                                    | timing loop 5-36                                              |
| slack 1-4                                                          | breaking manually 5-37                                        |
| slew 5-10                                                          | timing paths 1-7                                              |
| source latency 2-3, 2-7                                            | attributes 7-20                                               |
| specifying paths 3-4                                               | collection 7-19                                               |
| efficiency 3-23                                                    | critical 1-8                                                  |
| order or precedence 3-26                                           | delay calculation 1-14                                        |
| SPEF 6-26                                                          | grouping 1-31                                                 |
| Standard Delay Format (SDF) 6-2                                    | overview 3-1                                                  |
| Star-RCXT 1-39                                                     | specification 3-4                                             |
| startpoint of timing path 3-16                                     | timing point attributes 7-22                                  |
| static timing analysis                                             | timing report 7-10                                            |
| overview 1-2                                                       | timing_clock_reconvergence_pessimism                          |
| syncrhonous clocks 2-14                                            | variable 4-19                                                 |
| Synopsys Design Constraints (SDC) 1-19 synthesis design rules 1-40 | timing_crpr_remove_clock_to_data_crp variable 4-19            |
| Symmosic design raises 1 10                                        | timing_crpr_threshold_ps variable 4-20                        |
| Т                                                                  | timing_remove_clock_reconvergence_<br>pessimism variable 4-18 |
| time borrowing 1-17                                                | transition time 2-4, 5-10                                     |
| latch-based designs 9-3                                            | clock network report 7-22                                     |
| timing                                                             | tree type 4-3                                                 |

two-phased clocks, latch-based designs 9-25

# U

unate clock signal 2-35 unateness 2-18, A-2 uncertainty 2-4, 2-8 use\_auto\_loop\_breaking variable 5-37

# V

variables
auto\_link\_disable 6-25
estimate\_io\_latency 2-38
timing\_clock\_reconvergence\_pessimism
4-19
timing\_crpr\_threshold\_ps 4-20
timing\_remove\_clock\_reconvergence\_
pessimism 4-18
use\_auto\_loop\_breaking 5-37
voltage and temperature scaling 4-15

## W

wire load models 1-27 wire load model 5-26 automatic selection 5-33 capacitance calculation 5-27 choosing 5-28 hierarchical cells 5-32 link library usage 5-31 minimum block size 5-33 modes 5-29 remove 5-31 report 5-35 reporting 5-34 RTL load annotation 6-27 selection group 5-32 setting 5-31 wire load selection group remove 5-32 set 5-32 write\_sdc command 1-20 write sdf command 6-12